用C语言怎么实现浮点数的四舍五入,保留两位小数点
4个回答
展开全部
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 );
}
展开全部
加0.5强制转int。这是取到整数的方法。其他位数道理差不多。2位的话你先乘100,加0.5强制转int,然后除回100。注意类型转换。除100要转double。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
float a=10.123;
a=((int)((a*100+5)/100))/100.0;//这个值应该就是保留两位小数点的值吧
a=((int)((a*100+5)/100))/100.0;//这个值应该就是保留两位小数点的值吧
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
printf("%4.2f",a);类似的,前面一个4是字的位数,后面一个2是两位小数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询