C 语言中的 round 函数
本文将介绍几种在 C 语言中使用 round
函数的方法。
使用 round
函数将浮点数舍入到最接近的整数并返回浮点数
round
函数是 C 标准库数学工具的一部分,定义在 <math.h>
头文件中。这个系列有三个函数-round
、roundf
和 roundl
。这些函数适用于不同类型的浮点数,每个函数都返回相应的类型值。需要注意的是,包括 math
头在内的源文件,需要使用 -lm
标志来链接库代码进行编译。在下面的示例代码中,我们演示了多个 float
字面值的转换,并将结果输出到控制台。注意 round
基本上是从零开始舍去。如果将积分值 -0
、+0
、NaN
或 INFINITY
作为参数传递,则返回相同的值。
#include <stdio.h>
#include <math.h>
#include <stdlib.h>
#include <fenv.h>
int main(void)
{
printf("round(+2.3) = %+.1f\n", round(2.3));
printf("round(+2.5) = %+.1f\n", round(2.5));
printf("round(+2.7) = %+.1f\n", round(2.7));
printf("round(-2.3) = %+.1f\n", round(-2.3));
printf("round(-2.5) = %+.1f\n", round(-2.5));
printf("round(-2.7) = %+.1f\n", round(-2.7));
exit(EXIT_SUCCESS);
}
输出:
round(+2.3) = +2.0
round(+2.5) = +3.0
round(+2.7) = +3.0
round(-2.3) = -2.0
round(-2.5) = -3.0
round(-2.7) = -3.0
使用 lround
函数将浮点数舍入到最接近的整数并返回整数类型
另一方面,lround
函数将整数舍入到最接近的整数,并返回积分值。这个系列有六个函数,其中一半的函数返回 long int
作为整数,其他的函数则返回 long long int
。lround
类似于 round
系列,将一半的实数从零开始舍入。
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <fenv.h>
int main(void)
{
printf("lround(+2.3) = %ld\n", lround(2.3));
printf("lround(+2.5) = %ld\n", lround(2.5));
printf("lround(+2.7) = %ld\n", lround(2.7));
printf("lround(-2.3) = %ld\n", lround(-2.3));
printf("lround(-2.5) = %ld\n", lround(-2.5));
printf("lround(-2.7) = %ld\n", lround(-2.7));
exit(EXIT_SUCCESS);
}
输出:
lround(+2.3) = 2
lround(+2.5) = 3
lround(+2.7) = 3
lround(-2.3) = -2
lround(-2.5) = -3
lround(-2.7) = -3
使用 ceil
函数将浮点数舍入到不小于参数的最小整数值
另外,ceil
函数可以用来将给定的浮点数四舍五入到不小于参数本身的最小整数值。与 round
函数类似,这个系列也有三个函数-ceil
、ceilf
和 ceill
,分别用于 float
、double
和 long double
类型。请注意,我们在 prinf
指定符字符串中包含+
号,它将自动为四舍五入的参数显示相应的符号。
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <fenv.h>
int main(void)
{
printf("ceil(+2.3) = %+.1f\n", ceil(2.3));
printf("ceil(+2.5) = %+.1f\n", ceil(2.5));
printf("ceil(+2.7) = %+.1f\n", ceil(2.7));
printf("ceil(-2.3) = %+.1f\n", ceil(-2.3));
printf("ceil(-2.5) = %+.1f\n", ceil(-2.5));
printf("ceil(-2.7) = %+.1f\n", ceil(-2.7));
exit(EXIT_SUCCESS);
}
输出:
ceil(+2.3) = 3.000000
ceil(+2.5) = 3.000000
ceil(+2.7) = 3.000000
ceil(-2.3) = -2.000000
ceil(-2.5) = -2.000000
ceil(-2.7) = -2.000000
Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.
LinkedIn