
C语言中计算e^x次方的程序过程纠错!!!
#include<stdio.h>voidmain(){longdoublex,ex,b,a;inti,j;scanf("%f",&x);ex=0.0;a=1.0;b=1...
#include <stdio.h>
void main()
{
long double x,ex,b,a;
int i,j;
scanf("%f",&x);
ex=0.0;
a=1.0;
b=1.0;
for (i=1;i<=10;i++)
{ex=ex+b/a;
a=i*a;
b=b*x;
}
printf("%.5f\n",ex);
}
求解为什么出来是个很大很大的数字???? 展开
void main()
{
long double x,ex,b,a;
int i,j;
scanf("%f",&x);
ex=0.0;
a=1.0;
b=1.0;
for (i=1;i<=10;i++)
{ex=ex+b/a;
a=i*a;
b=b*x;
}
printf("%.5f\n",ex);
}
求解为什么出来是个很大很大的数字???? 展开
2个回答
展开全部
将输入部分的%f改为%lf
double类型不是普通浮点类型,本身就不符合%f的条件
%f输入的是flout型的数据,只有4字节;而double类型有8字节
而且函数scanf不像函数printf那样,后者会实现自动转换而前者不能。如:printf中,若前面标志的是%f,而后面的数据是double型的变量保存的,那么系统会自动先将后面的数据转换成符合要求的数据类型再输出;而在scanf中,如果前面标志的是%f,而后面传入的地址是double类型的变量的地址,那么scanf会直接把数据按照flout类型的读取和存储方式存入double型的变量中,而在之后的处理中却将变量当做double型的数据来处理,自然会发生难以预料的结果。
表示纯手打,求采纳
double类型不是普通浮点类型,本身就不符合%f的条件
%f输入的是flout型的数据,只有4字节;而double类型有8字节
而且函数scanf不像函数printf那样,后者会实现自动转换而前者不能。如:printf中,若前面标志的是%f,而后面的数据是double型的变量保存的,那么系统会自动先将后面的数据转换成符合要求的数据类型再输出;而在scanf中,如果前面标志的是%f,而后面传入的地址是double类型的变量的地址,那么scanf会直接把数据按照flout类型的读取和存储方式存入double型的变量中,而在之后的处理中却将变量当做double型的数据来处理,自然会发生难以预料的结果。
表示纯手打,求采纳
展开全部
#include <stdio.h>
void main() {
double x,ex,b,a;
int i;
scanf("%lf",&x);
ex = 0.0;
a = 1.0;
b = 1.0;
for(i = 1;i <= 10;i++) {
ex = ex + b/a;
a = i * a;
b = b * x;
}
printf("%g\n",ex);
}
追问
能解释一下为啥lf就可以了吗??!!!多谢!
追答
读入/写出double类型数据的格式是"%lf",flaot用"%f"等,这个是规定,只能按规行事。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询