我试图解决以下问题:
令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;
}
为什么这两个不同,我在第一个做错了什么?
答案 0 :(得分:3)
在&#34;正确&#34;对于y
的每个新值,解决方案-5
再次从x
开始。在您的版本中,y
会继续从之前的值开始递增,因此第二次迭代涵盖[5,15]
,第三次[15,25]
,依此类推。
奇怪的额外变量j
涵盖了您希望y
每次覆盖的范围,但y
本身不会。
答案 1 :(得分:0)
在错误的代码中,变量y和z在循环开始时不会重置到其范围的开头。
更短的正确例子是:
display: table-cell
变量初始化可以直接放入循环中。 因为它们是微不足道的变量,所以没有性能损失。