在我们日常工作学习过程中,经常会遇到用C语言进行浮点数转整数的四舍五入,乍看题目简单,通过自己的一顿猛如虎的操作答案却不对。在学习实验中如果出现错误还可以进行挽救,可如果真正到项目实践出现错误就会造成一发不可收拾。所以本文就带大家了解一下在C语言中如何使用四舍五入。
Math.Round的使用
我们可以使用Math.Round函数来对decimal类型的数值进行“四舍五入”处理。来看下面的代码:
decimal levyMoney1 = 77.24m; decimal levyMoney2 = 24.56m; //设置保留一位小数并输出 ("money1对应的输出:" + Math.Round(levyMoney1, 1)).Dump(); ("money2对应的输出:" + Math.Round(levyMoney2, 1)).Dump();
输出结果如下:
结果跟我们期望的一致!但是事实真的是这样吗?让我们下面再看个示例。
decimal levyMoney3 = 50.35m;
decimal levyMoney4 = 50.45m;
//C#的Round函数都是采用Banker’s rounding(银行家算法),即:四舍六入五取偶
("money3对应的输出:" + Math.Round(levyMoney3, 1)).Dump();
("money4对应的输出:" + Math.Round(levyMoney4, 1)).Dump();
输出结果如下:
纳尼?输出的竟然都是50.4?和我们理解的“四舍五入”不一致啊!这是因为C#的Round函数都是采用Banker’s rounding(银行家算法),即:四舍六入五取偶。所以结果才都是50.4。
正确表达四舍五入
那么,如何才能正确地表达四舍五入呢?Round的方法有个重载,其中第三个参数(MidpointRounding)用来表示舍入的规范。因此,四舍五入可以通过设置该参数为MidpointRounding.AwayFromZero来达到目的,如下:
decimal levyMoney3 = 50.35m; decimal levyMoney4 = 50.45m; ("money3四舍五入对应的输出:" + Math.Round(levyMoney3, 1, MidpointRounding.AwayFromZero)).Dump(); ("money4四舍五入对应的输出:" + Math.Round(levyMoney4, 1, MidpointRounding.AwayFromZero)).Dump();
输出结果如下:
以上就是“c语言中如何四舍五入?”的详细内容,想要了解更多关于C语言的知识或者教程欢迎持续关注编程学习网
扫码二维码 获取免费视频学习资料
- 本文固定链接: http://phpxs.com/post/8945/
- 转载请注明:转载必须在正文中标注并保留原文链接
- 扫码: 扫上方二维码获取免费视频资料
查 看2022高级编程视频教程免费获取