#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 请教一下各位,为什么我这个没有实现模拟点击
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器