c - 如何将 float 舍入为 int?

标签 c math

假设我有:

55.3 and want 55
55.6 and want 56
81.1 and want 81
etc.

我一直在尝试使用round()函数,但它似乎一直给我所有小数位的最高值。

最佳答案

OP 尚未发布失败的代码。某些 OP 编码不正确。

使用round()是舍入 double正确方法在转换为 int 之前。当然必须在范围内。

#include <math.h>
#include <assert.h>

int round_to_int(double x) {
  x = round(x);
  assert(x >= INT_MIN);
  assert(x < (INT_MAX/2 + 1)*2.0);
  return (int) x;
}

参见How to test for lossless double / integer conversion?有关 assert() 的详细信息s。

为什么不使用 (int)(x + 0.5);

1)负数失败。

2) double 可能会失败略小于0.5作为x + 0.5可以四舍五入为1.0 .

3) 当精度为int时超过double ,最低有效位为 0.5 或 1.0 的值,x+0.5可能舍入到下一个整数。

4) 朴实无华,没有范围检查。

关于c - 如何将 float 舍入为 int?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34124737/

相关文章:

c - 我怎样才能加快crc32计算?

c - Printf 执行隐式转换

java - 试图在这里解决比例问题

qt - 如何通过给定的一组位置向量获得绕 2 个轴的旋转速度

javascript - 在 Javascript 中使用插入符号作为指数

c - 嵌套的 if-else 语句给我带来了问题

c - 读取映射文件并将其存储在缓冲区中

c - 函数指针,如何转换?

algorithm - O(n^c) ~= O(n*log n),哪个值有c?

algorithm - 如何在加权(无向)图中的两个节点之间找到长度为 X 的路径