浮点数比较注意

本文通过一个简单的浮点数加和程序示例揭示了在计算机中使用浮点数进行精确比较时可能遇到的问题。由于浮点数的表示限制,直接使用不等于运算符进行比较可能导致无限循环。文章建议使用小于等于的比较方式来避免此类问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

void main()
{
double sum=0;
for(double x=0.0;x!=5.5;x+=0.1)sum+=x;
}
上述程序用来计算加和0.1+0.2+...+5.4.这段程序在计算机上会陷入无限循环.因为计算机的精度有限,x永远不会达到5.5.
实际上,1/3和0.1这样的数在计算机上不可能精确的表示.
将这个for循环改为
for(double x=0.0;x<=5.5;x+=0.1)sum+=x;

结论:相等判断中包含浮点数应该格外小心,用比较表达式代替相等判断通常会使程序更加健壮!

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值