用C语言怎么实现浮点数的四舍五入,保留两位小数点

如题所述

C语言怎么实现浮点数的四舍五入,保留两位小数的设计过程为:

    定义浮点点数变量df,输入浮点数

    浮点数df扩大100倍

    浮点数df增加0.5

    利用floor()函数得到最接近df数,但不大于df的整数(完成四舍五入)。不能用int强制转换,否则,数据超过int范围就会出现错误。

    浮点数df缩小100倍得到有两位小数的浮点数

    按%.2f输出结果。

参考代码:

#include <stdio.h>
#include <math.h>
void main()
{
    double df=0;
    printf("input d: "); scanf("%lf", &df );
    df *= 100 ;
    df += 0.5 ;
    df =floor(df);
    df /= 100;
    printf("d=%.2f\n", df );
}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2011-03-23
加0.5强制转int。这是取到整数的方法。其他位数道理差不多。2位的话你先乘100,加0.5强制转int,然后除回100。注意类型转换。除100要转double。
第2个回答  2011-03-23
float a=10.123;
a=((int)((a*100+5)/100))/100.0;//这个值应该就是保留两位小数点的值吧本回答被提问者采纳
第3个回答  2011-03-23
printf("%4.2f",a);类似的,前面一个4是字的位数,后面一个2是两位小数
相似回答