C#小数计算的坑
今天做项目碰到的事情,是根据权重计算平均分。
现有4个组员,1个组长,所有组员权重70%,组长权重30%。
组员打分分别为:4分、5分、5分、3分,组长打分为:5分
根据权重规则有以下表达式:
(4+5+5+3)/4*0.7+5*0.3
正确的计算结果应该是4.475,而C#计算出来的是4.3,那么这个4.3是怎么来的?
经过追踪,我发现在(4+5+5+3)/4这里就出现了问题,它这里的计算结果为17/4=4,4*0.7+5*0.3=4.3。
原因可能为:
整数除整数,默认以整数结果保留
找到了问题所在,那么解决问题也就是简单的事情了。
参与计算之前将该数转换为decimal:
//ZZ是组长分数,zySum是组员总分,length是组员总数
//注意:如果因为逻辑易读性写成 AvgNum = zySum / Length * 0.70M + zz * 0.30M 则会发生以上小数位丢失的问题,
//因为zySum是整数,而length也是整数,解决方法是在zySum参与计算之前,将其转换成decimal类型,如下:
//AvgNum = zySum*1.00M / Length * 0.70M + zz * 0.30M
AvgNum = zz * 0.30M + zySum * 0.70M / Length;