int与float类型数据问题
问题在代码注释那里#include <stdlib.h>
int main()
{
int b;//为什么当int b时输入45输出7.00但当float b时同样输入45但输出7.22?
float a;
printf("请输入华氏度 :");
scanf("%d",&b);
a = (b-32) * 5/9;
printf("转换为摄氏度为 :%.2f\n",a);
return 0;
}
本帖最后由 yuxijian2020 于 2021-5-12 20:39 编辑
#include <stdlib.h>
int main()
{
int b;
float a;
printf("请输入华氏度 :");
scanf("%d",&b);
a = (b-32) * 5/9; //这里把int 隐式转换为 float ,计算结果就是 7 转为 float 后就是 7.0000000
printf("转换为摄氏度为 :%.2f\n",a); //这里显示小数点后2位 ,7.0000000 -> 7.00
return 0;
} 本帖最后由 肖-肖 于 2021-5-12 20:50 编辑
为什么当int b时输入45输出7.00
int b=45 (45-32)*5/9=13*5/9=65/9=7
因为%.2f所以是:7.00
float b时同样输入45但输出7.22?
我想说的是:如果你只改了b的数据类型而不改scanf中的接受类型的话,本身代码就是有问题的,应该改为%f
至于它输出什么?那也不必研究了吧 肖-肖 发表于 2021-5-12 20:46
为什么当int b时输入45输出7.00
int b=45 (45-32)*5/9=13*5/9=65/9=7
因为%.2f所以是:7.00
改过%f后为什么输出的是7.22 本帖最后由 肖-肖 于 2021-5-13 16:55 编辑
王之叹息 发表于 2021-5-13 16:45
改过%f后为什么输出的是7.22
输出7.22是正确的,不是吗? 肖-肖 发表于 2021-5-13 16:54
输出7.22是正确的,不是吗?
那那那不是问为什么吗,你看你第一次那个得7的时候就列了个算式,大佬再讲讲这个呗。 王之叹息 发表于 2021-5-13 20:18
那那那不是问为什么吗,你看你第一次那个得7的时候就列了个算式,大佬再讲讲这个呗。
为什么当float b时输入45输出7.22?
差不多是一样的:
float b=45.00 (45.00-32)*5/9=13.00*5/9=65.00/9=7.2222222222222
7.2 2的无线循环
然后:%.2f 代表只保留2位小数:所以结果是:7.22
肖-肖 发表于 2021-5-13 16:54
输出7.22是正确的,不是吗?
okok了,大概知道了。不用再回了,一直以为/号就一种运算方式 {:10_323:} {:10_279:} 向大佬学习
学习学习
学习学习
学习学习
学习学习 {:10_279:}{:10_279:} {:10_261:}{:10_261:} 感谢分享! yue了 学习了
页:
[1]
2