#include<stdio.h>
int main(void) {
int m=2, a=5, b=4;
float c=3.0, d=4.0;
printf("%.2f,%.2f\n", (a/b)*m, (a/d)*m);
printf("%.2f,%.2f\n", (a/d)*m, (a/b)*m);
return 0;
}
结果是:
2.50,0.00
2.50,-5487459522906928958771870404376799406808566324353377030104786519743796498661129086808599726405487030183023928761546165866809436788166721199470577627133198744209879004896284033606071946689658593354711574682628407789000148729336462084532657713450945423953627239707603534923756075420253339949731915621203968.00
我想知道造成这种差异的原因。
但是,如果我将 int 更改为 float ,答案与我预期的相同。
结果是:
2.50,2.50
2.50,2.50
答案 0 :(得分:1)
请注意,a/b
如果int
为int
,则为float
,如果至少有float
,则a/b
为int
,其他算术运算符类似。因此,在float
中,如果它们都是int
s,那么5/4 = 1;如果至少有一个是float
,那么5 / 4.0 = 5.0 / 4.0 = 1.25,因为编译器会在任何具有另一个浮点数的算术之前自动将%.2f
转换为int
。所以你的结果预计会有所不同。
但在您的情况下,即使输出print
s,您似乎也会使用int
格式。因此float
获取具有int
的四个字节,并尝试解码这四个字节,就像它们有一些int
编码一样。在%d
s的内存中,Flot编号的编码方式非常不同 - 就像采用匈牙利文本和tryint来解释它一样,就好像它是用英文编写的,即使字母是相同的 - 得到的“解释”将只是垃圾。
您需要做什么:任何float
都应该使用%f
以及任何{{1}} {{1}}或类似格式输出。
答案 1 :(得分:1)
您使用的是错误的格式说明符,请尝试以下操作:
#include<stdio.h>
int main(void)
{
int m=2,a=5,b=4;
float fm=2,fa=5,fb=4;
float c=3.0,d=4.0;
//First expression in this printf is int and second is float due to d
printf("%d , %.2f\n\n",(a/b)*m,(a/d)*m);
//Second expression in this printf is int and first is float due to d
printf("%.2f , %d\n\n",(a/d)*m,(a/b)*m);
printf("%.2f , %.2f\n\n",(fa/b)*fm,(fa/d)*fm);
printf("%.2f , %.2f\n\n",(fa/d)*fm,(fa/b)*fm);
return 0;
}
输出:
2 , 0
0 , 1074003968
2.50 , 2.50
2.50 , 2.50
C99标准第7.19.6.1节第9节说:
如果任何参数不是相应转换规范的正确类型,则行为未定义。
答案 2 :(得分:0)
您正在尝试打印整数值
printf("%d,%.2f\n",(a/b)*m,(a/d)*m);
printf("%.2f , %d\n\n",(a/d)*m,(a/b)*m);
为了打印整数值,你应该使用%d
使用错误的格式说明符导致未定义的行为
答案 3 :(得分:0)
如果你想让结果浮动它们:
#include <stdio.h>
int main(void) {
// your code goes here
int m=2,a=5,b=4;
float c=3.0,d=4.0;
printf("%.2f,%.2f\n",(float)(a/b)*m,(float)(a/d)*m);
printf("%.2f,%.2f\n", (float) (a/d)*m,(float)((a/b)*m));
return 0;
}
希望这会有所帮助.. :)