嵌套循环行为怪异

Nested loop acting weird

本文关键字:嵌套循环      更新时间:2023-10-16

编辑:张贴一切,因为它真的很奇怪。

using namespace std;
int main()
{
int doors = -1;
int jumper = 1;
bool isOpen[100];
string tf;
for(int i = 0 ; i < 100; i++){
    isOpen[i] = false;
}
while(jumper < 100){
    while(doors < 100){
        if(isOpen[doors + jumper] == true){
            isOpen[doors + jumper] = false;
        }
        else{
            isOpen[doors + jumper] = true;
        }
        doors += jumper;
        cout << doors << endl;
    }
    doors = -1;
    jumper+=1;
}
for(int i = 0; i < 100; i++){
    if(isOpen[i]){
        tf = "open";
    }
    else{
        tf = "closed.";
    }
    cout << "Door " << i << " is " << tf << endl;
}
return 0;

}

我在这段代码中遇到了一个非常奇怪的问题。它应该遍历一个包含100个元素的数组。0 - 99分,1分,2分,3分等等。然而,在a = 10之后,它飙升到266。有人能告诉我为什么吗?

编辑:只有当for循环被注释掉时才会出现这个问题。当它留在代码中,它做同样的事情,但直到19才发生。如果我也注释掉"字符串tf;",它将继续在99处循环。这都是基于门的数量。我不确定为什么这两个都应该是循环的一个因素,这两个都没有连接。

根据你的描述,你应该这样做:

for(int adv = 1, i = 0; adv < 100;)
{
   // i is array index (your b) -> use it somehow:
   doSomething(arr[i]);
   i += adv;
   if(i >= 100)
   {
       i = 0;
       adv++;
   }
}

你得到奇怪的行为(包括266值)的(可能的)原因是你的代码溢出了缓冲区。当b足够高时(比如99),你将写入isOpen[b + a],它将是100或更高(如果a是1,则为100,这只是第一次迭代,以后的迭代将会更进一步)。如果编译器在整数之前分配isOpen,您将覆盖它们。