рекурсивный возврат — моя программа на С ++ работает, но, скажем, «8queens.exe перестал работать»

этот код пытается решить проблему 4 ферзей, помещая 4 ферзей на шахматную доску 4 * 4, при этом ни одна из них не может захватить друг друга

#include <iostream>
using namespace std;

int Place(int Chess[][4], int collumn, int i);
bool Check(int Chess[][4], int collumn, int i);
int findrow(int Chess[][4], int collumn);
const int size = 3;
int main()
{
int Chess[4][4];
int collumn;
int i = 0;
collumn = 0;

for(int s = 0; s < 4; s++)
{
for(int j = 0; j < 4; j ++)
{
Chess[s][j] = 0;

}
}
//Chess[0][0] = 1;
//Chess[3][3] = 1;
//if(Check(Chess, 3, 3) == false)

Place(Chess, collumn, i);
for(int z = 0; z < 4; z++)
{
for(int a = 0; a < 4; a++)
{

if(Chess[z][a] == 1)

cout<<"Row: "<<z<<"Collumn: "<<a<<"."<<endl;
}
cout<<endl;
}
system("pause");
return 0;

}int Place(int Chess[][4], int collumn, int i)
{
if(collumn > size)
return 0;
while(i <= size)
{
if(Check(Chess, collumn, i) == true)
{
//cout<<"hi"<<endl;
Chess[collumn][i] = 1;
return(Place(Chess, (collumn + 1), i));
}
i ++;
}
if(i>= size)
{
//cout<<"hilo"<<endl;
return Place(Chess, collumn-1, findrow(Chess, collumn-1));
}
}

bool Check(int Chess[][4], int collumn, int i)//checks to see if it can be captured
{// very inneficitnt
int x = collumn;// this is so we can now work in terms of x and y
int y = i;

bool found = true;// checks all the diagonal captures
if(Chess[x -1 ][y -1]== 1&& x>=1 && y >=1 )
found = false;
if(Chess[x -2 ][y - 2]== 1&& x>=2 && y>=2 )
found =  false;
if(Chess[x - 3][y - 3]== 1 && x>=3 && y>=3 )
found =  false;
if(Chess[x + 1][y - 1] == 1&& x<=2 && y>=1 )
found = false;
if(Chess[x + 2][y -2]  == 1&& x<=1 && y>=2)
found = false;
if(Chess[x + 3][y - 3] == 1 && x<=0 && y>=3)
found =  false;
if(Chess[x + 1][y + 1] == 1 && x<=2 && y<=2)
found = false;
if(Chess[x + 2][y + 2]  == 1&& x<=1 && y<=1)
found = false;
if(Chess[x + 3][y + 3] == 1 && x<=0 && y<=0 )
found =  false;
if(Chess[x -1 ][y + 1]== 1 && x>=1 && y<=2 )
found =  false;
if(Chess[x - 2][y + 2] == 1&& x>=2 && y<=1 )
found = false;
if(Chess[x - 3][y + 3]  == 1&& x>=3 && y<=0)
found = false;

//checks all the horizontal captures.  We don't need to check for vertical captures
if(Chess[x + 1][y] == 1 && x<=2)
found = false;
if(Chess[x + 2][y] == 1&& x<=1 )
found = false;
if(Chess[x+3][y] == 1 && x<=0)
found = false;
if(Chess[x -1 ][y]  == 1&& x>=1)
found =  false;
if(Chess[x-2][y] == 1&& x>=2 )
found = false;
if(Chess[x-3][y]  == 1 && x>=3)
found =  false;

if(found == false)
return false;

if(found == true)
return true;
}

int findrow(int Chess[][4], int collumn)
{
for(int z = 0; z < 4; z++)
{
if(Chess[collumn][z] == 1)
{
Chess[collumn][z] = 0;
return z;
}
}
}

0

Решение

Первое, что я вижу, это вероятный выход за пределы:

if(Chess[x -1 ][y -1]== 1&& x>=1 && y >=1 )

Что делать, если значение x является 0? Вы получаете доступ к шахматам [-1] [y], выход за пределы. Ваш if заявление не останавливает это, даже с x>=1 состояние.

if сначала проверим Chess[x-1][y-1]==1 состояние. Если вы хотите, чтобы этого не произошло, поместите тест для x>=1 до Chess[x-1][y-1]==1,

Но даже при этом весь этот фрагмент кода выглядит подозрительно. Я не удивлюсь, если бы было больше за пределами доступа.

3

Другие решения


По вопросам рекламы [email protected]