欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 能源 > 浮点数截断法:四舍五入的精确模拟

浮点数截断法:四舍五入的精确模拟

2025/5/17 8:16:21 来源:https://blog.csdn.net/zyq99101_1/article/details/148016864  浏览:    关键词:浮点数截断法:四舍五入的精确模拟

理论解释:

1. 目标

假设 a = 3.14159,我们想四舍五入到 小数点后两位(即 3.143.15)。

2. 步骤拆解

     (1) a * 100

  • a 放大 100 倍,让小数点后两位变成整数部分:
  • 3.14159 * 100 = 314.159

    (2) + 0.5

  • 关键步骤:如果小数部分 ≥ 0.5,则整数部分 +1
  • 314.159 + 0.5 = 314.659
  • 如果原数是 3.146(即 314.6),则:

  • 314.6 + 0.5 = 315.1

    (3) (int) 强制截断

  • 强制转换为 int丢弃小数部分(不是四舍五入,而是直接截断):
  • (int)314.659 = 314
    (int)315.1 = 315

    这样:

  • 314.159 → 314(因为 0.659 < 1,相当于 3.14159 舍去)
  • 314.6 → 315(因为 0.1 < 1,但整数部分已经是 315,相当于 3.146 进位)

     (4) / 100.0

  • 最后缩小 100 倍,恢复原来的数量级:
  • ​314 / 100.0 = 3.14
    315 / 100.0 = 3.15

    3. 为什么能保证精确?

  • 浮点数存储可能不精确(如 3.145 可能存储为 3.144999999...),直接用 %.2f 可能会错误舍入。
  • (int)(x + 0.5) 是经典的“四舍五入”方法,不依赖浮点数的内部表示,而是利用整数截断特性,确保:
  • 小数部分 ≥ 0.5 → 进位
  • 小数部分 < 0.5 → 舍去

例题:

代码如下:

错误示例

(1)

(2)

(3)

正确代码:

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词