C语言不同数据类型数据运算时的类型转换问题

初学C语言,请问为什么下列代码中5、9、32在遇到浮点型变量后没有和浮点型变量一起转换为double型?
代码:

#include<stdio.h>
int main()
{
float F,C;
printf("请输入华氏温度:");
scanf("%f",&F);
C=(5/9)*(F-32);
printf("对应摄氏温度为:%.2f",C);
return 0;
}

上文代码输出:

请输入华氏温度:96
对应摄氏温度为:0.00

尝试过的方法:

将5、9、32转换为5.0、9.0、32.0后可输出期望结果;
将5、9、32分别赋给三个声明为float的变量可以输出期望结果;
将5、9、32分别赋给三个声明为int的变量不可以输出期望结果。

期望输出:

输入96返回35.56

5/9是两个整数相除,是进行整除操作,结果会是0,你的错误主要是这个原因。
改成5.0/9,5/9.0,或者5*(F-32)/9 等都可以。

这是除法运算那里的问题,除法需要注意三种情况:

第一种情况,被除数除以除数,小数部分会被抹去。
比如:9/2=4,-9/2=-4
第二种情况,被除数如果小于除数,结果会为0。
比如:1/2=0
(像你上面那个5/9算出来会直接为0)
第三种情况 ,不管是被除数,还是除数只要有一个为浮点数,即结果为浮点数。
比如:1.0/2=0.5
(你的代码就需要改为,5.0/9或是5/9.0,结果都会是浮点数。)

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632