嵌套循环的两个区别。(C ++)

时间:2015-05-26 17:42:46

标签: c++ nested-loops

我试图解决以下问题:

令x,y,z为域[-5,5]中的整数。显示满足3 * x + y ^ 3-z ^ 2 = 0的解(x,y,z)的数量。我最初的解决方案是:

int main() {
    int x=-6;
    int y=-6;
    int z=-6;
    int p=0;
    for(int i=-5; i<6; i++)
    {
        x++;
        for (int j=-5; j<6; j++)
        {
            y++;
            for(int k=-5; k<6; k++)
            {
                z++;
                if(3*x +y*y*y -z*z==0)
                    p++;          
            }
        }
    }
    std::cout<< p ;
    return 0;
}

这是正确的解决方案:

 int main() {
        int x=-5;
        int y=-5;
        int z=-5;
        int p=0;
        for( x=-5; x<=5; x++)
           for (y=-5; y<=5; y++)
               for( z=-5; z<=5; z++)
                   if(3*x +y*y*y -z*z==0)
                       p++;

        std::cout<< p;
        return 0;
}

为什么这两个不同,我在第一个做错了什么?

2 个答案:

答案 0 :(得分:3)

在&#34;正确&#34;对于y的每个新值,解决方案-5再次从x开始。在您的版本中,y会继续从之前的值开始递增,因此第二次迭代涵盖[5,15],第三次[15,25],依此类推。

奇怪的额外变量j涵盖了您希望y每次覆盖的范围,但y本身不会。

答案 1 :(得分:0)

在错误的代码中,变量y和z在循环开始时不会重置到其范围的开头。

更短的正确例子是:

display: table-cell

变量初始化可以直接放入循环中。 因为它们是微不足道的变量,所以没有性能损失。