C相同的输出结果不同

时间:2015-01-22 03:57:05

标签: c

#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

4 个答案:

答案 0 :(得分:1)

请注意,a/b如果intint,则为float,如果至少有float,则a/bint,其他算术运算符类似。因此,在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;
}

希望这会有所帮助.. :)