qq_37032457
2016-12-27 14:04
采纳率: 50%
浏览 2.6k

为什么C++中不能用浮点数控制for循环?

为什么C++中不能用浮点数控制for循环?
如:
for (double y = 0.1; y != 1.0; y +=0.1)
cout << y << endl;
这段代码有什么问题吗?为什么循环会停不下来?
本人大一学生,各位大神,求解?

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

4条回答 默认 最新

  • 耕耘中的小人物 2016-12-27 15:33
    已采纳

    首先,你的代码是符合C++语法的,并没有规定不可以用浮点数控制for循环。
    之所以一般代码不用浮点数,我能想到的,有两个原因:
    1.没必要,性能还低,一般for循环直接控制循环次数,整数作循环计数速度比浮点数要快
    2.麻烦。循环判断条件里面,一般不直接用相等或者不等逻辑运算符判断两个浮点数是否相等,因为浮点数存在误差,
    一般使用if(x > 9.9999 && x < 10.00001)这种方式来替代if(x == 10.0)这种方式

    点赞 评论
  • 智者知已应修善业 2016-12-27 14:11

    为何非要用小数去作循环计数,有必要?循环计数就是循环计数,循环体内要作什么都可以。

    点赞 评论
  • KFPA 2016-12-28 00:50

    完全没有必要用浮点数,只能降低程序性能!

    点赞 评论
  • 绿野耕夫 2016-12-28 01:43

    建议你回去再翻翻书,看看浮点数的相等和不等是怎么判断的。
    就你这个循环来说,把y != 1.0改成y < 1.0

    点赞 评论

相关推荐 更多相似问题