C如何计算int和float数据类型混合



[已解决]

我正在学习C,在学习过程中遇到了一些问题。

当我试图在一个等式中计算int数据类型和float数据类型时,我得到了两个不同的输出。我很困惑,因为从逻辑上讲,结果应该是一样的。

这是我的代码版本1和版本2。差异在于变量z。

  • 第一种情况:z的值为1
  • 第二种情况:z的值为0

所有输入都是11

更新1

感谢大家的评论和回答。但我仍然困惑于变量p在情况1中扮演的角色,以及它如何导致变量z为1而不是0?

案例1

int main()
{
float a, fee, p;
int x, y,z;
scanf("%f", &a);
fee = 0.6 * a;
x = (int)(fee);
y = (int)(2 * fee - 2 * x);
p = fee * 10.0;
z = (int)(p - 10 * x - 5 * y);
printf("%f %d %d %d", fee, x, y, z);
return 0;
}

情况2

int main()
{
float a, fee, p;
int x, y,z;
scanf("%f", &a);
fee = 0.6 * a;
x = (int)(fee);
y = (int)(2 * fee - 2 * x);
z = (int)(fee * 10.0 - 10 * x - 5 * y);
printf("%f %d %d %d", fee, x, y, z);
return 0;
}
1) z = (int)(p - 10 * x - 5 * y);
F    I   I   I   I            // Float or Int
2) z = (int)(fee * 10.0 - 10 * x - 5 * y); // semicolon removed
F     D      I   I   I   I   // Float, Double or Int

1)中的所有计算都是以float精度进行的,2)中的计算都以double精度进行。

建议:使用浮点值时,始终首选double

如果将小于1的浮点数(如0.9f)强制转换为INT,它将变为零。

相关内容

  • 没有找到相关文章

最新更新