C语言怎么实现浮点数的四舍五入,保留两位小数的设计过程为:
定义浮点点数变量df,输入浮点数
浮点数df扩大100倍
浮点数df增加0.5
利用floor()函数得到最接近df数,但不大于df的整数(完成四舍五入)。不能用int强制转换,否则,数据超过int范围就会出现错误。
浮点数df缩小100倍得到有两位小数的浮点数
按%.2f输出结果。
参考代码:
#include
#include
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 );
}
加0.5强制转int。这是取到整数的方法。其他位数道理差不多。2位的话你先乘100,加0.5强制转int,然后除回100。注意类型转换。除100要转double。
float a=10.123;
a=((int)((a*100+5)/100))/100.0;//这个值应该就是保留两位小数点的值吧
printf("%4.2f",a);类似的,前面一个4是字的位数,后面一个2是两位小数