#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;
}
大佬们看看程序有问题吗 为什么算带小数的数时最后几位有时不正确?
- 写回答
- 好问题 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 很想要一个很好的答案或提示