seb’s 2021-09-22 16:26 采纳率: 100%
浏览 31
已结题

不能理解C语言中的带小数的运算逻辑。为什么cm/30.48 的结果这么奇怪?求解运算逻辑?

代码如下:

img

img

**不能理解C语言中的带小数的运算逻辑。为什么cm/30.48 的结果这么奇怪?求解运算逻辑?**

  • 写回答

3条回答 默认 最新

  • 於黾 2021-09-22 16:30
    关注

    因为170/30.48结果是个double型
    而你用%d输出的是int型,输出之前你又没有将结果强制转换成int,导致它把double型的前4个字节当做int输出
    而你输出foot的时候就很正常,因为foot本身是int型,double已经隐式的转换为了int
    这种丢失精度的转换在c++,c#等类似的语法中是不允许的,但是c中允许。

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

报告相同问题?

问题事件

  • 系统已结题 10月2日
  • 已采纳回答 9月24日
  • 创建了问题 9月22日

悬赏问题

  • ¥15 2024-五一综合模拟赛
  • ¥15 下图接收小电路,谁知道原理
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
  • ¥15 ETLCloud 处理json多层级问题
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭