【C语言】将一个浮点数四舍五入保留两位小数
【C语言】将一个浮点数四舍五入保留两位小数
第一次做这个题目的时候,我用了一个比较傻的方法:利用强制类型转换可以得到该浮点数的整数部分,然后分别取出十分位、百分位、千分位上的数字,判断千分位上的数字是否大于等于5,若是则百分位进一,再将这几个数字乘以系数后相加即可
关于如何获取某一位上数字的方法在另一篇博客中有详细说明
#include <stdio.h> int main(int argc, const char * argv[]) { double f = 123.4567; //获得整数部分 int a = (int)f; //获取十分位部分 int b = (int)(f*10)%10; //获取百分位部分 int c = (int)(f*100)%10; //获取千分位部分 int d = (int)(f*1000)%10; //判断千分位是否大于等于5 if (d >= 5) { //是,百分位进一位 c ++; } //乘以系数后相加 double e = a + b*0.1 + c*0.01; printf("a = %d ",a); printf("b = %d ",b); printf("c = %d ",c); printf("d = %d ",d); printf("e = %f ",e); return 0; }
这个方法显然是很傻的(看见题目的时候脑子没转过弯来),下面介绍比较常用的方法
- 如何进行四舍五入 假设要从某一位进行四舍五入,很自然能想到判断它后一位上的数字是否大于等于5,其实可以直接给这个数字加上5,就能跳过判断的过程了 例如 100.1123 四舍五入保留整数: 100.1 + 0.5 = 100.61 取整后为100 100.7123 四舍五入保留整数: 100.7 + 0.5 = 101.21 取整后为101 但是,假如要进行小数位的四舍五入,光利用这个特性是不够的,例如 100.1123 四舍五入保留两位小数:100.1123 + 0.005 = 100.1173 100.1173 四舍五入保留两位小数:100.1173 + 0.005 = 100.1253 怎样将百分位后的数去掉呢?
- 如何处理小数位的四舍五入 可以利用强制转换为int型时,截断的特性来实现 例如 int a = 0.75 实际上 a 赋值为0,小数部分被截断了 利用这个特性,可以将要保留的数据挪到整数位,然后强制转换为int型,再转回所求的数字即可 #include <stdio.h> int main(int argc, const char * argv[]) { double f = 123.4567; //1.进行四舍五入 f = f + 0.005; //2.将要保留的数据挪到整数位,再取整 int temp = f*100; //一步到位 //int temp = (f+0.005)*100; //3.转为所需数字 f = temp/100.0; printf("f = %f ",f); return 0; } 当然,也可以先转为int型再进行四舍五入,结果都是一样的 #include <stdio.h> int main(int argc, const char * argv[]) { double f = 123.4567; //取整的同时四舍五入 int temp = (int)(f*100+0.5); //转为所需数字 f = temp/100.0; printf("f = %f ",f); return 0; } 注 由于float类型的有效数字为6~7位,可能存在六位以后的数据不正确的情况,所以为了保证精度,在需要较长的浮点数时最好使用double型
下一篇:
数据库的内,外连接方式