S1E8华氏度摄氏度转换
#include <stdio.h>int main() {
int F;
printf("请输入华氏度:");
scanf("%d", &F);
float S;
S = (F - 32) * 5 / 9;
printf("转换为摄氏度是:%.2f\n", S);
return 0;
}
如题,华氏度使用整型变量在输出摄氏度时会损失小数点后的数据,请问这是为什么 因为你在输入的时候它就已经损失了 也就是只能接收整数部分因为你用的%d 肖-肖 发表于 2021-5-17 20:44
因为你在输入的时候它就已经损失了 也就是只能接收整数部分因为你用的%d
啊,为什么会输入的时候就损失呢,int变量不就是%d吗{:10_272:} S = (F - 32) * 5 / 9;
赋值时 计算右边的整式时就丢失了
自动转换 万千只cnm 发表于 2021-5-17 20:54
S = (F - 32) * 5 / 9;
赋值时 计算右边的整式时就丢失了
自动转换
意思是左边的式子计算出来先处理成整型再赋值的吗,那这个是因为变量F是整型才这样处理的吗 C++太极门小弟子 发表于 2021-5-17 21:00
意思是左边的式子计算出来先处理成整型再赋值的吗,那这个是因为变量F是整型才这样处理的吗
先计算右边整式的值F是整型右边整式的值就是整形然后再赋值
当然丢失了
全改成float
floatF;
scanf(“%f”,&F); C++太极门小弟子 发表于 2021-5-17 20:52
啊,为什么会输入的时候就损失呢,int变量不就是%d吗
因为只能接收整数的部分
而小数的部分就丢失了呀
即使你后来的S是浮点数的又有什么用呢?
所以关键还是输入时就已经丢失了 万千只cnm 发表于 2021-5-17 21:04
先计算右边整式的值F是整型右边整式的值就是整形然后再赋值
当然丢失了
噢噢噢那就是取决于F的数据类型是吧 C++太极门小弟子 发表于 2021-5-17 21:24
噢噢噢那就是取决于F的数据类型是吧
自动转换是 往“精确”的转换
可以给个最佳答案嘛 万千只cnm 发表于 2021-5-17 22:49
自动转换是 往“精确”的转换
可以给个最佳答案嘛
懂了,谢谢{:10_266:}
页:
[1]