今天编程学习网为大家讲解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\n",a);
printf("b = %d\n",b);
printf("c = %d\n",c);
printf("d = %d\n",d);
printf("e = %f\n",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\n",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\n",f);
return 0;
}
注:
由于float类型的有效数字为6~7位,可能存在六位以后的数据不正确的情况,所以为了保证精度,在需要较长的浮点数时最好使用double型
以上就是“C语言:将一个浮点数四舍五入保留两位小数”的详细内容,想要了解更多C语言教程欢迎持续关注编程学习网
扫码二维码 获取免费视频学习资料
- 本文固定链接: http://phpxs.com/post/10333/
- 转载请注明:转载必须在正文中标注并保留原文链接
- 扫码: 扫上方二维码获取免费视频资料