简单循环中C 程序中的错误

Bug in c++ program during a simple loop

本文关键字:错误 程序 单循环 简单      更新时间:2023-10-16

我正在尝试尽可能少的代码行解决此问题。

问题语句:
有人设法向打招呼打招呼,如果可以从键入单词中删除几个字母,以便导致" Hello"一词...我正在测试他是否可以

#include <iostream>
int main() {
    char c;
    int i=0; 
    while(i!=5 && (cin>>c) && c!='n'){
        if(c=="hello"[i])
            i++;
    }
    cout<<((i==5)?"YES":"NO");
}

当应该打印"否"时,有一个错误。该程序等待更多输入。我认为循环直到i==5才能完成,但是当c=='n'

时,循环永远不会完成

在打包程序以最大程度地减少LOC之前(我认为您有一个很好的理由关心这一点,因为否则这是愚蠢的事情)使其正确!

尝试在CIN>> C测试之前对I!= 5测试。否则,当您获得" Hello"

时,您会阅读一个额外的角色

编辑:要清楚,问题中的代码现已修改以包含此建议。

您有一个way loop

while(i!=5 && (cin>>c) && c!='n')
{ ... }

...您可以重写以更轻松的调试。通常,而不是任何循环...

while (X)
{ Y }

...您也可以写...

while (true)
{
    if (!X) break;
    Y
}

对于您的循环,那将是此代码:

while (true)
{
    if (!(i!=5 && (cin>>c) && c!='n'))
        break;
    ...
}

现在,我假设您知道逻辑和操作员的短路评估。如果没有,请搜索该术语!有了这些知识,您可以这样重写循环:

while (true)
{
    if (!(i!=5))
        break;
    if (!(cin>>c))
        break;
    if (!(c!='n'))
        break;
    ...
}

当然,您仍然可以简化一些双重否定,但是这个想法应该很清楚。现在,此更改使您可以在调试器中逐步浏览此问题,以分别评估每个循环出口条件。这很重要,因为第二个环条件也具有副作用!此外,您可以添加一些调试输出,以告诉您循环退出的原因。此外,对于具有副作用的检查,您可以检查中间状态(如果愿意,如果您愿意以这种方式输出状态),这将使您对问题的进一步见解。

最后,istreams上的所有>>运算符默认情况下,包括空格,选项卡和新线,因此您的最后一次检查永远不会导致循环退出。您可以告诉流不要跳过空格,如果那是您想要的。如何做到这一点应该很简单,可以使用另一个Websearch查找。;)