C 语言中的 round 函数

Jinku Hu 2023年10月12日
  1. 使用 round 函数将浮点数舍入到最接近的整数并返回浮点数
  2. 使用 lround 函数将浮点数舍入到最接近的整数并返回整数类型
  3. 使用 ceil 函数将浮点数舍入到不小于参数的最小整数值
C 语言中的 round 函数

本文将介绍几种在 C 语言中使用 round 函数的方法。

使用 round 函数将浮点数舍入到最接近的整数并返回浮点数

round 函数是 C 标准库数学工具的一部分,定义在 <math.h> 头文件中。这个系列有三个函数-roundroundfroundl。这些函数适用于不同类型的浮点数,每个函数都返回相应的类型值。需要注意的是,包括 math 头在内的源文件,需要使用 -lm 标志来链接库代码进行编译。在下面的示例代码中,我们演示了多个 float 字面值的转换,并将结果输出到控制台。注意 round 基本上是从零开始舍去。如果将积分值 -0+0NaNINFINITY 作为参数传递,则返回相同的值。

#include <fenv.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.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 intlround 类似于 round 系列,将一半的实数从零开始舍入。

#include <fenv.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.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 函数类似,这个系列也有三个函数-ceilceilfceill,分别用于 floatdoublelong double 类型。请注意,我们在 prinf 指定符字符串中包含+ 号,它将自动为四舍五入的参数显示相应的符号。

#include <fenv.h>
#include <math.h>
#include <stdio.h>
#include <stdlib.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
作者: Jinku Hu
Jinku Hu avatar Jinku Hu avatar

DelftStack.com 创始人。Jinku 在机器人和汽车行业工作了8多年。他在自动测试、远程测试及从耐久性测试中创建报告时磨练了自己的编程技能。他拥有电气/电子工程背景,但他也扩展了自己的兴趣到嵌入式电子、嵌入式编程以及前端和后端编程。

LinkedIn Facebook

相关文章 - C Math