小白求解
int main(){
int F ;
float D ;
printf("请输入华氏度:");
scanf("%d",&F);
D = (F-32) *5/9;
printf("转换为摄氏度是:%.2f\n",D);
return 0;
}
为什么这样写是错误的,通过输入一个十进制的整数来计算,得出的小数点后两位都是0 因为你是把运算后的整型数变成了浮点型
在(F-32)前加上(float)即可 因为F是int类型,在执行D = (F-32) *5/9时,右侧的运算会以int类型进行除法计算,结果也是int类型然后在转化成float赋值给D,这就导致运算结果的小数部分都是00
解决方法:1、将F定义为float;2、将D = (F-32) *5/9;的右侧写成浮点运算,例如:D = (F-32) *5.0/9; 系统会把不同的类型的数据自动转换,比如会把整型转换成浮点型 墨羽岚 发表于 2020-3-17 17:08
因为你是把运算后的整型数变成了浮点型
在(F-32)前加上(float)即可
感谢施教! sunrise085 发表于 2020-3-17 17:13
因为F是int类型,在执行D = (F-32) *5/9时,右侧的运算会以int类型进行除法计算,结果也是int类型然后在转 ...
感谢施教! sunrise085 发表于 2020-3-17 17:13
因为F是int类型,在执行D = (F-32) *5/9时,右侧的运算会以int类型进行除法计算,结果也是int类型然后在转 ...
请问一下这样写D = (F-32) *5.0/9 是什么意思 5改成5.0就可以改变int型了吗 卑微者 发表于 2020-3-17 17:42
请问一下这样写D = (F-32) *5.0/9 是什么意思 5改成5.0就可以改变int型了吗
c语言计算中若参有小数点则将结果也带上小数点(当然最终结果还是看表达式) 墨羽岚 发表于 2020-3-17 17:47
c语言计算中若参有小数点则将结果也带上小数点(当然最终结果还是看表达式)
明白了,感谢!
页:
[1]