I was one of my test code below:
data:image/s3,"s3://crabby-images/84322/84322960ef9b435a46864f320b5ef5f2ecd06d3d" alt=""
If use % f, the input value is wrong;
data:image/s3,"s3://crabby-images/1a6ec/1a6ec976c647320e743db2c9f8026456fa0769e5" alt=""
If the scanf function with % lf, the result is right;
data:image/s3,"s3://crabby-images/ba47e/ba47e1a8857f5aaa58b6f2f40113c4da4a061c1e" alt=""
Why is this? I see another answer, just type double make use % f,
I use the compiler is DEVC++ 5.11.
CodePudding user response:
Double input is 8 bytes, a float is 4 bytes, output use % f no problem, may be improved type,CodePudding user response:
Since testing, validation, that shows that people say may be limited to the compiler, or other people say ~ if you have any questionsCodePudding user response:
data:image/s3,"s3://crabby-images/f97b8/f97b87056c4984217bf83a6db8e74a0f45088deb" alt=""
CodePudding user response:
You define a double, the scanf with lf, floating point Numbers is very troublesome, see stackCodePudding user response:
https://blog.csdn.net/weixin_44997886/article/details/102812153reference
CodePudding user response:
# include & lt; stdio.h>
Int main () {
Float f=1.234567 f;
Double lf=1.234567890123456;
Printf (" % f, % 15 lf \ n ", f, lf);//1.234567, 1.234567890123456
Printf (" % f, % f 15 \ n ", f, lf);//1.234567, 1.234567890123456
Printf (" % % lf, 15 lf \ n ", f, lf);//1.234567, 1.234567890123456
Char [] s="1.234567890123456";
F=0.0 f; Sscanf (s, "% f", & amp; F); Printf (" % f \ n ", f);//1.234568
Lf=0.0; Sscanf (s, "% lf", & amp; Lf); Printf (" % 15 lf \ n ", lf);//1.234567890123456
Lf=0.0 f; Sscanf (s, "% f", & amp; Lf); Printf (" % 15 lf \ n ", lf);//0.000000000000000
F=0.0; Sscanf (s, "% lf", & amp; F); Printf (" % f \ n ", f);//70.175720
return 0;
}
//based on the above results available: printf, lf and % % f can be mixed, the scanf when no,
CodePudding user response:
Double is to use % lfFloat use % f
Why don't tangle,
Think about a double can use % d for?
Your problem now is similar to "type double variables, using the scanf function format character % d, why mistake?"
No why, be in the wrong
CodePudding user response:
% % f is a float single precision, lf is a double double precision, so the calculation results are different