#include<stdio.h>
void main()
{
float a;
int b;
printf("请输入一个浮点数\n");
scanf("%f",&a);
b=(int)(a*100+0.5);
a=b/100.0;
printf("%lf\n",&a);
}
为什么不能实现小数点后 取两位 并四舍五入
# incloud <stdio>
int main(void)
{
float a ;
scanf(“%f”,&a);
a=(int)(a*1000+0.5)/1000.0;
printf (“%0.3f”,a);
return 0;
}
扩展资料:
其他方法实现四舍五入:
int myround(double indata,int precision,double * outdata)
{
long pre = 1,i;
for(i = 0; i <precision; i ++)pre = pre * 10;
if(cy_FloatCompare(indata,0.00)> 0)
* outdata =(int)((indata * pre)+0.5)/100.00;
else
* outdata =(int)((indata * pre)-0.5)/100.00;
return 0;
}
// cy_FloatCompare是浮点数与0比较的函数,假设它存在。返回值与strcmp相同。
温馨提示:答案为网友推荐,仅供参考
第1个回答 2008-12-14
将 printf("%lf",&a);
改为 printf("%.2f",a);
其中 %.2f 是控制输出的语句,表示输出时小数点后保留两位数。如果计算结果的小数点后的数位大于二则四舍五入,小数点后保留两位;若计算结果小数后没有达到两位,则输出时补零,所以输出的结果小数点后仍然有两位数。
而“&”用在输入输出语句中表示取地址,
而且只能用在输入时,表示取你要赋值的变量的地址,从而将你所输入的值传递给你要赋值的变量,而上面用在输入时显然是错的本回答被提问者采纳
改为 printf("%.2f",a);
其中 %.2f 是控制输出的语句,表示输出时小数点后保留两位数。如果计算结果的小数点后的数位大于二则四舍五入,小数点后保留两位;若计算结果小数后没有达到两位,则输出时补零,所以输出的结果小数点后仍然有两位数。
而“&”用在输入输出语句中表示取地址,
而且只能用在输入时,表示取你要赋值的变量的地址,从而将你所输入的值传递给你要赋值的变量,而上面用在输入时显然是错的本回答被提问者采纳
第2个回答 2008-12-14
#include<stdio.h>
void main()
{
float a;
int b;
printf("请输入一个浮点数\n");
scanf("%f",&a);
b=(int)(a*100+0.5);
a=b/100.0;
printf("%lf\n",a); //这里改一下,把你a前面的那个&去掉
}
void main()
{
float a;
int b;
printf("请输入一个浮点数\n");
scanf("%f",&a);
b=(int)(a*100+0.5);
a=b/100.0;
printf("%lf\n",a); //这里改一下,把你a前面的那个&去掉
}
第3个回答 2008-12-14
printf("%lf\n",&a);
倒数第二行错了
应该是
printf("%lf\n",a);
倒数第二行错了
应该是
printf("%lf\n",a);
第4个回答 2008-12-14
将这一句:
scanf("%f",&a);
改为:
scanf("%.2f",&a);
scanf("%f",&a);
改为:
scanf("%.2f",&a);