[已解决]
我正在学习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,它将变为零。