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

  1. 如果使用float 之后输出都必须改成%f??

  2. 使用double 必须使用%lf 我用%f 就会随机数字... 

  3. 我用的double 双精度 为啥小数还是6位?

  4. 这个警告是怎么回事

  5. 前4问我用这个程序尝试的

  6. 58232630000110c404560497.jpg

  7. 5823263000013f2205000153.jpg

丶辉色灬
浏览 3453回答 1
1回答

只是一菜鸟

定义某个类型后,输出的时候也要输出相应的类型,否则可能会出错或者造成输出的数值不精确。针对你这个问题:%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。因为系统会认为空格就是字符,这样的话,三个数据必须连续输入,且中间那个必须是符号才行,否则就会出现问题了。希望对你有帮助。
打开App,查看更多内容
随时随地看视频慕课网APP