编写一个函数,作用是保留两位小数,对第三位四舍五入···我写的程序如下#includefloat fun (double);int main(){double a;float b;printf("请输入一个浮点数:%lf\n",&a);b=fun(a);printf("转换后的浮点数为:%12.2f\n",b
来源:学生作业帮助网 编辑:作业帮 时间:2024/11/15 17:03:38
编写一个函数,作用是保留两位小数,对第三位四舍五入···我写的程序如下#includefloat fun (double);int main(){double a;float b;printf("请输入一个浮点数:%lf\n",&a);b=fun(a);printf("转换后的浮点数为:%12.2f\n",b
编写一个函数,作用是保留两位小数,对第三位四舍五入···
我写的程序如下
#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,搞不懂,这个是为什么呢~
编写一个函数,作用是保留两位小数,对第三位四舍五入···我写的程序如下#includefloat fun (double);int main(){double a;float b;printf("请输入一个浮点数:%lf\n",&a);b=fun(a);printf("转换后的浮点数为:%12.2f\n",b
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);
}