现今支付宝、微信支付方式流行,省去了现金交易和找零操作,给人们的生活带来了极大的便利。现金操作时,商家一般会将分四舍五入。而计算机在进行收银操作时是如何对分实现四舍五入的呢?
当前我们已经学习了“第2章 数据类型、运算符与表达式”,可以编程模拟超市结账时将多出的分实现四舍五入。例如小明在某超市购买的商品总价格为35.55元,抹去分后小明实际应支付35.60元。
解题思路:结账时应付金额,一般是实型数据,用变量a表示。而float实型数据在内存中存储时小数位数一般是6位,double实型数据类型在内存中存储时小数位数一般是15位。因此参与运算时并不是应付金额本身参与运算。
在实现对分四舍五入时,需要首先将应付金额,小数点后第3位四舍五入,即将小数点向后移2位后加上0.5,然后将得到的新数取整,直接舍去小数部分,用int型变量m表示。
再对应付金额小数点后第2位,即分四舍五入。其方法是:将第2步得到的整数除以10.0,变为实数,加上0.5,然后将得到的新数取整,直接舍去小数部分,用int型变量n表示。
最后,将得到的最新整数n 除以10.0,即得到实付金额,用变量b表示。
实付金额输出时,采用%.2f的格式输出,保留小数位数2位,第3位小数系统自动四舍五入。
程序调试:
(1)程序中定义变量没有赋初值,系统会给定任意的初值
(2)输入应付金额a值为35.55,在内存中的存储如下:
35.55在内存中存储的是35.549999,因此,参与运算的并不是35.55!
(3)计算完后,各变量的值在内存中的存储如下:
(4)输出结果如下:
注意:计算得到的实付金额b值在内存中为35.599998,利用printf("实付金额:%.2f\n",b);输出b值,输出格式%.2f,表示输出数据保留小数位数2位,系统自动将第3位四舍五入,整数部分原样输出,因此输出结果为35.60。而%f输出数据小数位数,系统默认按6位输出,输出结果将为35.599998。