【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;
}

这个方法显然是很傻的(看见题目的时候脑子没转过弯来),下面介绍比较常用的方法

  1. 如何进行四舍五入
    假设要从某一位进行四舍五入,很自然能想到判断它后一位上的数字是否大于等于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
    怎样将百分位后的数去掉呢?
  2. 如何处理小数位的四舍五入
    可以利用强制转换为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型