
c语言问题 编写一个函数,作用是保留两位小数,对第三位四舍五入···
我写的程序如下#include<stdio.h>floatfun(double);intmain(){doublea;floatb;printf("请输入一个浮点数:%l...
我写的程序如下
#include<stdio.h>
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,搞不懂,这个是为什么呢~~高手告诉我啊·~~
在线等待·~~ 展开
#include<stdio.h>
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,搞不懂,这个是为什么呢~~高手告诉我啊·~~
在线等待·~~ 展开
3个回答
展开全部
printf是输出把
scanf才是输入
整理如下
#include<stdio.h>
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);
}
scanf才是输入
整理如下
#include<stdio.h>
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);
}
展开全部
printf("请输入一个浮点数:%lf\n",&a);
不能直接在printf里面输入吧,你没有scanf语句
改为printf("请输入一个浮点数:");
scanf("%lf",&a);
不能直接在printf里面输入吧,你没有scanf语句
改为printf("请输入一个浮点数:");
scanf("%lf",&a);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
printf("请输入一个浮点数:%lf\n",&a);
这句话写得不正确,改成两句话:
printf("请输入一个浮点数");
scanf("%f",&a);
再试试
这句话写得不正确,改成两句话:
printf("请输入一个浮点数");
scanf("%f",&a);
再试试
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询