发布网友 发布时间:2022-04-22 14:12
共4个回答
热心网友 时间:2022-06-08 13:55
#include
main()
{
double
a;
printf("请输入一个四位小数:\n");
scanf("%lf",&a);//双精度应该是的%lf
a*=100;//
扩大100倍,举个例子:a=123.4567,a=a*100,则a=12345.67
a+=0.5;//加0.5进行四舍五入a=12346.17
a=(int)a;//这个地方是想保留两位小数,后边的舍去,所以进行强制类型转换.
a/=100;//上面扩大100倍,现在要对其缩小100
printf("结果是:%f\n",a);//这样就行了,或者printf("结果是:%.2f\n",a);
}
热心网友 时间:2022-06-08 13:55
scanf("%d",&a);改为:
scanf("%lf",&a);
printf("结果是:%2f\n",a);改为:
printf("结果是:%.2f\n",a);
%2f
是按2位输出,%.2f是按小数部分保留两位输出,一失足成千古恨啊。小心呀
热心网友 时间:2022-06-08 13:56
应该是精度问题。
因你使用的是float变量,你可以用printf显示a*100的结果是155.499995而不是155.50000
你可以全改成double型
#include
<stdio.h>
double
fun
(
double
h
)
{
return
(long)(
h
*
100
+0.5
)/
100.0;
}
main(
)
{
double
a;
printf
("enter
a:
");
scanf
(
"%lf",
&a
);
printf
(
"the
original
data
is
:
"
);
printf
(
"%lf
%lf\n\n",
a,
a*100
);
printf
(
"the
result
:
%lf\n",
fun
(
a
)
);
}
热心网友 时间:2022-06-08 13:56
这样相当于取整,a*=1000;a+=5;a/=10;a/=100.0;这样就可以了!
设a为1.256,由a*=1000;得a=1256;由a+=5;得a=1231;由a/=10;得a=123;由a/=100.0;得a=1.230000;后面的不变。