=5)c=(t+1)*0.01;elsec=t*0.01;c=e+c;return (c);}但是程序在运行的时候确实这样子的:请输入一个浮点数:0.000000转换后的浮点数为:0.00Press any key to continue都没让我输入,就直接0.000000,搞不懂,这个是为什么呢~" /> =5)c=(t+1)*0.01;elsec=t*0.01;c=e+c;return (c);}但是程序在运行的时候确实这样子的:请输入一个浮点数:0.000000转换后的浮点数为:0.00Press any key to continue都没让我输入,就直接0.000000,搞不懂,这个是为什么呢~ - 作业答案大全" />

编写一个函数,作用是保留两位小数,对第三位四舍五入···我写的程序如下#includefloat fun (double);int main(){double a;float b;printf("请输入一个浮点数:%lf\n",&a);b=fun(a);printf("转换后的浮点数为:%12.2f\n",b);return 0;}float fun (double h){int e,r,t;float c;e=(int)(h);t=(int)(h*100);t=t%100;r=(int)(h*1000);r=r%10;if(r>=5)c=(t+1)*0.01;elsec=t*0.01;c=e+c;return (c);}但是程序在运行的时候确实这样子的:请输入一个浮点数:0.000000转换后的浮点数为:0.00Press any key to continue都没让我输入,就直接0.000000,搞不懂,这个是为什么呢~

问题描述:

编写一个函数,作用是保留两位小数,对第三位四舍五入···
我写的程序如下
#include
float fun (double);
int main()
{
double a;
float b;
printf("请输入一个浮点数:%lf\n",&a);
b=fun(a);
printf("转换后的浮点数为:%12.2f\n",b);
return 0;
}
float fun (double h)
{
int e,r,t;
float c;
e=(int)(h);
t=(int)(h*100);
t=t%100;
r=(int)(h*1000);
r=r%10;
if(r>=5)
c=(t+1)*0.01;
else
c=t*0.01;
c=e+c;
return (c);
}
但是程序在运行的时候确实这样子的:
请输入一个浮点数:0.000000
转换后的浮点数为:0.00
Press any key to continue
都没让我输入,就直接0.000000,搞不懂,这个是为什么呢~

printf是输出把
scanf才是输入
整理如下
#include
float fun (double);
int main()
{
double a;
float b;
printf("请输入一个浮点数:");
sanf("%f",&a);
b=fun(a);
printf("转换后的浮点数为:%12.2f\n",b);
return 0;
}
float fun (double h)
{
int e=(int)(h*100.0);
e%=10;
if(e>=5)
h+=0.01;
return (h);
}