蓝色123经典 2019-07-16 16:05 采纳率: 75%
浏览 440
已采纳

大佬们看看程序有问题吗 为什么算带小数的数时最后几位有时不正确?

#include
int main(void)
{
float money,change,number,price;
printf("请输入您购买的物品的单价(元):");
scanf("%f",&price);
printf("请输入您购买的物品的数目(个):");
scanf("%f",&number);
printf("请输入您的付款(元):");
scanf("%f",&money);
change=money-number*price;
printf("找您的%f元!祝您购物愉快!",change);
getchar();
getchar();
return 0;
}

  • 写回答

1条回答 默认 最新

  • gg思无邪 2019-07-16 16:21
    关注

    float能够表示7位有效数字,但是能够保证精度的是6位。
    如果你的计算结果或者是输入的值,超过了6位有效数字,并不能保证进度。
    double也是同样的,能够表示16位有效数字,能够保证15精度。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 数值计算均差系数编程
  • ¥15 redis-full-check比较 两个集群的数据出错
  • ¥15 Matlab编程问题
  • ¥15 训练的多模态特征融合模型准确度很低怎么办
  • ¥15 kylin启动报错log4j类冲突
  • ¥15 超声波模块测距控制点灯,灯的闪烁很不稳定,经过调试发现测的距离偏大
  • ¥15 import arcpy出现importing _arcgisscripting 找不到相关程序
  • ¥15 onvif+openssl,vs2022编译openssl64
  • ¥15 iOS 自定义输入法-第三方输入法
  • ¥15 很想要一个很好的答案或提示