为了账号安全,请及时绑定邮箱和手机立即绑定

C语言 如果使用float 之后输出都必须改成%f??

C语言 如果使用float 之后输出都必须改成%f??

C C++
丶辉色灬 2016-11-09 21:36:19
如果使用float 之后输出都必须改成%f??使用double 必须使用%lf 我用%f 就会随机数字... 我用的double 双精度 为啥小数还是6位?这个警告是怎么回事前4问我用这个程序尝试的
查看完整描述

1 回答

已采纳
?
只是一菜鸟

TA贡献20条经验 获得超29个赞

定义某个类型后,输出的时候也要输出相应的类型,否则可能会出错或者造成输出的数值不精确。

针对你这个问题:

%f和%lf分别是float类型和double类型用于格式化输入输出时对应的格式符号。

在用于输出时:
float类型可以使用%lf格式,但不会有任何好处。
double类型如果使用了%f格式可能会导致输出错误。

在用于输入时:
double 类型使用了%f格式,会导致输入值错误。
float类型使用double类型不仅会导致输入错误,还可能引起程序崩溃。

所以在输入输出时,一定要区分好double和float,而使用对应的格式符号。

--------------

用double 后,要多少位小数,根据需要自己设定。 否则会默认保留6位小数。

--------------

至于那个警告,我估计可能是你在输出的时候,两个double类型中放入了char类型,所以提示这样可能不安全。可以试试分开输入,应该就不会了。

===============

我刚才测试了下,输入格式化分别为:double、char、double的时候,如果输入的三个数据都是double时,会直接处理前两个数据。

例如:

#include<stdio.h>
int main()
{
	double x,y;
	char c;
	scanf("%lf%c%lf",&x,&c,&y);
	printf("%lf",x+y);
	return 0;
}

输入:1  2  3

输出的则是3,而不是4。

因为系统会认为空格就是字符,这样的话,三个数据必须连续输入,且中间那个必须是符号才行,否则就会出现问题了。

希望对你有帮助。

查看完整回答
3 反对 回复 2016-11-10
  • 1 回答
  • 1 关注
  • 3350 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信