C++太极门小弟子 发表于 2021-5-17 20:26:59

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;
}
如题,华氏度使用整型变量在输出摄氏度时会损失小数点后的数据,请问这是为什么

肖-肖 发表于 2021-5-17 20:44:05

因为你在输入的时候它就已经损失了 也就是只能接收整数部分因为你用的%d

C++太极门小弟子 发表于 2021-5-17 20:52:32

肖-肖 发表于 2021-5-17 20:44
因为你在输入的时候它就已经损失了 也就是只能接收整数部分因为你用的%d

啊,为什么会输入的时候就损失呢,int变量不就是%d吗{:10_272:}

万千只cnm 发表于 2021-5-17 20:54:41

S =   (F - 32) * 5 / 9;
赋值时    计算右边的整式时就丢失了
自动转换

C++太极门小弟子 发表于 2021-5-17 21:00:29

万千只cnm 发表于 2021-5-17 20:54
S =   (F - 32) * 5 / 9;
赋值时    计算右边的整式时就丢失了
自动转换

意思是左边的式子计算出来先处理成整型再赋值的吗,那这个是因为变量F是整型才这样处理的吗

万千只cnm 发表于 2021-5-17 21:04:14

C++太极门小弟子 发表于 2021-5-17 21:00
意思是左边的式子计算出来先处理成整型再赋值的吗,那这个是因为变量F是整型才这样处理的吗

先计算右边整式的值F是整型右边整式的值就是整形然后再赋值

当然丢失了
全改成float   
floatF;
scanf(“%f”,&F);

肖-肖 发表于 2021-5-17 21:11:49

C++太极门小弟子 发表于 2021-5-17 20:52
啊,为什么会输入的时候就损失呢,int变量不就是%d吗

因为只能接收整数的部分
而小数的部分就丢失了呀
即使你后来的S是浮点数的又有什么用呢?
所以关键还是输入时就已经丢失了

C++太极门小弟子 发表于 2021-5-17 21:24:44

万千只cnm 发表于 2021-5-17 21:04
先计算右边整式的值F是整型右边整式的值就是整形然后再赋值

当然丢失了


噢噢噢那就是取决于F的数据类型是吧

万千只cnm 发表于 2021-5-17 22:49:59

C++太极门小弟子 发表于 2021-5-17 21:24
噢噢噢那就是取决于F的数据类型是吧

自动转换是   往“精确”的转换

可以给个最佳答案嘛

C++太极门小弟子 发表于 2021-5-18 22:13:21

万千只cnm 发表于 2021-5-17 22:49
自动转换是   往“精确”的转换

可以给个最佳答案嘛

懂了,谢谢{:10_266:}
页: [1]
查看完整版本: S1E8华氏度摄氏度转换