C语言如何输入双精度数据?
main(){doublea,b;scanf("%f,%f",&a,&b);a+=b;printf("a+b=%f",a);}程序本身很简单,请问在上面的程序运行时输入两...
main()
{
double a,b;
scanf("%f,%f",&a,&b);
a+=b;
printf("a+b=%f",a);
}
程序本身很简单,请问在上面的程序运行时输入两个数据:10,10,为什么得不到20.000000?
在输入时,将格式修改为%lf即可,为什么%f不可以呢?
大家没有理解问题的实质。结果是20.000000,其中的小数位数是由%f决定的,本人没有异议,在输出时无需改成%lf,更无需 用格式控制其输出的小数位数。
关键问题是,scanf("%f,%f",&a,&b);不能输入双精度数据吗?如果超过范围发生溢出正常,但输入10,10为什么就得不到20这个结果呢?
大家可以把上述程序运行下,看得到的结果是怎么算出来的? 展开
{
double a,b;
scanf("%f,%f",&a,&b);
a+=b;
printf("a+b=%f",a);
}
程序本身很简单,请问在上面的程序运行时输入两个数据:10,10,为什么得不到20.000000?
在输入时,将格式修改为%lf即可,为什么%f不可以呢?
大家没有理解问题的实质。结果是20.000000,其中的小数位数是由%f决定的,本人没有异议,在输出时无需改成%lf,更无需 用格式控制其输出的小数位数。
关键问题是,scanf("%f,%f",&a,&b);不能输入双精度数据吗?如果超过范围发生溢出正常,但输入10,10为什么就得不到20这个结果呢?
大家可以把上述程序运行下,看得到的结果是怎么算出来的? 展开
6个回答
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询