萌新求问,为什么这里的c/10=0.699999988呢?
在做小甲鱼第一季的课后练习(S1E9)的动动手第一题,为什么我的按揭成数c除以10的时候是0.699999988呢,既不是0.7,就算是精度损失,那为什么又不是0.7000000001,也不是0.699999999,搞不懂那2个8怎么来的,因为这些我最后算出来的结果和答案不太一样(虽然差距很小但感觉不能随便忽略)。我用的Dev C++(5.11),不知哪里出了问题,想请大佬赐教。#include <stdio.h>
#include <math.h>
int main()
{
float d;
float a,b,c,yir;
printf("请输入单价(元/平方):");
scanf("%f",&a) ;
printf("请输入面积:");
scanf("%f",&b) ;
printf("请输入按揭成数:");
scanf("%f",&c) ;
printf("请输入按揭年数:");
scanf("%f",&d) ;
a=6000,b=120,c=7,d=20;
printf("请输入当前基准年利率:");
scanf("%f",&yir) ;
// 开始计算结果
printf("=======报告结果=======\n");
float m=d*12;
float r=yir/12;
//房款总额
float total0=a*b;
// 首期付款
float first=total0*(1-c/10);
// 贷款总额
float p=total0*c/10;
// 月均还款
float x=p*(r/100*pow((1+r/100),m))/(pow((1+r/100),m)-1);
// 还款总额
float total=m*(float)x;
// 支付利息
float total_lx=m*(float)x-p;
// 输出结果
printf("m=%.2f\n",m);
printf("房款总额;%.2f元\n",total0);
printf("首期付款;%.2f元\n",first);
printf("贷款总额;%.2f元\n",p);
printf("还款总额;%.2f元\n",total);
printf("支付利息;%.2f元\n",total_lx);
printf("月均还款;%.2f元\n",x);
return 0;
}
这个就是精度误差,误差成什么样不是你能控制的。
我手上没开vs,测试不了,你可以试试用 double 或 long double ,或许误差会变小? 与字符串的长度/或者说精度有关。
在计算机的2进制,与显示的10进制过程中,会有误差。
后来在PYTHON中这个问题,就解决的了。
对于本题,把金额对应到分正确就可以了。 补充一下,
十进制中的“1“
在二进进制中表示;1/2+1/4+1/8+1/16+1/32+……无穷尽~~~ fly3412 发表于 2020-4-19 23:50
补充一下,
十进制中的“1“
在二进进制中表示;1/2+1/4+1/8+1/16+1/32+……无穷尽~~~
十进制中的一在二进制也是一 浮点数都不是完全准确的数字,只能追求精度,像python,java,0.1+0.1可以为循环小数. 永恒的蓝色梦想 发表于 2020-4-19 22:11
这个就是精度误差,误差成什么样不是你能控制的。
我手上没开vs,测试不了,你可以试试用 double 或 long...
确实用double误差变小了,但是跟题目小甲鱼的结果在小数点后第二位上还是有1~2的差距,讲道理都是C语言,应该都一样啊,为什么会有差距呢,而且答案也是用的float呢
lovelysea 发表于 2020-4-20 15:34
确实用double误差变小了,但是跟题目小甲鱼的结果在小数点后第二位上还是有1~2的差距,讲道理都是C语言, ...
可能是机器的原因?
不过你纠结这个误差是完全没有意义的
页:
[1]