编程学习网 > 编程语言 > C/C++开发 > C语言:将一个浮点数四舍五入保留两位小数
2022
11-10

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\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语言教程欢迎持续关注编程学习网

扫码二维码 获取免费视频学习资料

Python编程学习

查 看2022高级编程视频教程免费获取