鱼C论坛

 找回密码
 立即注册
查看: 1669|回复: 7

[已解决]萌新求问,为什么这里的c/10=0.699999988呢?

[复制链接]
发表于 2020-4-19 22:11:25 | 显示全部楼层 |阅读模式
2鱼币
在做小甲鱼第一季的课后练习(S1E9)的动动手第一题,为什么我的按揭成数c除以10的时候是0.699999988呢,既不是0.7,就算是精度损失,那为什么又不是0.7000000001,也不是0.699999999,搞不懂那2个8怎么来的,因为这些我最后算出来的结果和答案不太一样(虽然差距很小但感觉不能随便忽略)。我用的Dev C++(5.11),不知哪里出了问题,想请大佬赐教。

调试图,C/10的值在左上角

调试图,C/10的值在左上角


  1. #include <stdio.h>
  2. #include <math.h>

  3. int main()
  4. {
  5.         float d;
  6.         float a,b,c,yir;
  7.         printf("请输入单价(元/平方):");
  8.         scanf("%f",&a) ;
  9.         printf("请输入面积:");
  10.         scanf("%f",&b) ;
  11.         printf("请输入按揭成数:");
  12.         scanf("%f",&c) ;
  13.         printf("请输入按揭年数:");
  14.         scanf("%f",&d) ;
  15.         a=6000,b=120,c=7,d=20;
  16.         printf("请输入当前基准年利率:");
  17.         scanf("%f",&yir) ;
  18. //        开始计算结果
  19.         printf("=======报告结果=======\n");
  20.         float m=d*12;
  21.         float r=yir/12;
  22. //  房款总额
  23.         float total0=a*b;
  24. //        首期付款
  25.         float first=total0*(1-c/10);
  26. //        贷款总额
  27.         float p=total0*c/10;
  28. //        月均还款
  29.         float x=p*(r/100*pow((1+r/100),m))/(pow((1+r/100),m)-1);
  30. //        还款总额
  31.         float total=m*(float)x;
  32. //        支付利息
  33.         float total_lx=m*(float)x-p;
  34. //        输出结果
  35.         printf("m=%.2f\n",m);
  36.         printf("房款总额;%.2f元\n",total0);
  37.         printf("首期付款;%.2f元\n",first);
  38.         printf("贷款总额;%.2f元\n",p);
  39.         printf("还款总额;%.2f元\n",total);
  40.         printf("支付利息;%.2f元\n",total_lx);
  41.         printf("月均还款;%.2f元\n",x);
  42.        
  43.         return 0;
  44. }  
复制代码

左(小甲鱼) 右(我的运行结果)

左(小甲鱼) 右(我的运行结果)



最佳答案
2020-4-19 22:11:26
这个就是精度误差,误差成什么样不是你能控制的。
我手上没开vs,测试不了,你可以试试用 double 或 long double ,或许误差会变小?

最佳答案

查看完整内容

这个就是精度误差,误差成什么样不是你能控制的。 我手上没开vs,测试不了,你可以试试用 double 或 long double ,或许误差会变小?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-19 22:11:26 | 显示全部楼层    本楼为最佳答案   
这个就是精度误差,误差成什么样不是你能控制的。
我手上没开vs,测试不了,你可以试试用 double 或 long double ,或许误差会变小?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-19 23:45:13 | 显示全部楼层
与字符串的长度/或者说精度有关。
在计算机的2进制,与显示的10进制过程中,会有误差。
后来在PYTHON中这个问题,就解决的了。
对于本题,把金额对应到分正确就可以了。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-19 23:50:54 | 显示全部楼层
补充一下,
十进制中的“1“
在二进进制中表示;  1/2+1/4+1/8+1/16+1/32+……  无穷尽~~~
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-20 08:42:49 | 显示全部楼层
fly3412 发表于 2020-4-19 23:50
补充一下,
十进制中的“1“
在二进进制中表示;  1/2+1/4+1/8+1/16+1/32+……  无穷尽~~~

十进制中的一在二进制也是一
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-20 09:17:33 | 显示全部楼层
浮点数都不是完全准确的数字,只能追求精度,像python,java,0.1+0.1可以为循环小数.
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2020-4-20 15:34:09 | 显示全部楼层
永恒的蓝色梦想 发表于 2020-4-19 22:11
这个就是精度误差,误差成什么样不是你能控制的。
我手上没开vs,测试不了,你可以试试用 double 或 long  ...

确实用double误差变小了,但是跟题目小甲鱼的结果在小数点后第二位上还是有1~2的差距,讲道理都是C语言,应该都一样啊,为什么会有差距呢,而且答案也是用的float呢
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-20 15:38:39 | 显示全部楼层
lovelysea 发表于 2020-4-20 15:34
确实用double误差变小了,但是跟题目小甲鱼的结果在小数点后第二位上还是有1~2的差距,讲道理都是C语言, ...

可能是机器的原因?
不过你纠结这个误差是完全没有意义的
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-6 09:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表