蒜味橙 2022-03-21 14:35 采纳率: 100%
浏览 91
已结题

整型和浮点型相除,int foot=cm/30.48; int foot=cm/100/0.3048; 为什么两个结果不一样?

如果已知英制长度的英尺foot和英寸inch的值,那么对应的米是(foot+inch/12)×0.3048。现在,如果用户输入的是厘米数,那么对应英制长度的英尺和英寸是多少呢?别忘了1英尺等于12英寸。

输入格式:
输入在一行中给出1个正整数,单位是厘米。

输出格式:
在一行中输出这个厘米数对应英制长度的英尺和英寸的整数值,中间用空格分开。
满分答案贴出来,不过有一些问题请教。

#include<stdio.h>
int main()
{
    int cm,foot,inch;
    scanf("%d",&cm);
    foot=cm/30.48;
    inch=((cm/30.48)-foot)*12;
    printf("%d %d",foot,inch);
    return 0;
}

为什么foot=cm/30.48; inch=((cm/30.48)-foot)*12; 这里(cm/30.48)-foot 不等于0;
foot=cm/30.48; int foot=cm/100/0.3048; 这两种写法为什么结果不一样?

  • 写回答

4条回答 默认 最新

  • 关注

    int foot=cm/100/0.3048这么写的时候,先计算cm/100,100默认是int类型,所以cm/100的结果也默认是int类型,假如cm=12,那么cm/100=0,而不是0.12,所以用 int foot=cm/100/0.3048的时候,得到的结果是损失了数据精度的。
    而 foot=cm/30.48这么写的时候,cm会直接被提升为float类型,计算的结果也是float类型,不会损失数据。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 3月30日
  • 已采纳回答 3月22日
  • 创建了问题 3月21日