mirror of
https://hub.njuu.cf/TheAlgorithms/C-Plus-Plus.git
synced 2023-10-11 13:05:55 +08:00
60 lines
1.2 KiB
C++
60 lines
1.2 KiB
C++
|
#include<bits/stdc++.h>
|
||
|
# define n 8
|
||
|
using namespace std;
|
||
|
bool issafe(int x,int y,int sol[n][n])
|
||
|
{
|
||
|
return (x<n && x>=0 && y<n && y>=0 && sol[x][y]==-1);
|
||
|
|
||
|
}
|
||
|
bool solve(int x,int y, int mov, int sol[n][n], int xmov[n], int ymov[n])
|
||
|
{
|
||
|
int k,xnext,ynext;
|
||
|
|
||
|
if(mov == n*n)
|
||
|
return true;
|
||
|
|
||
|
for(k=0;k<8;k++)
|
||
|
{
|
||
|
xnext=x+xmov[k];
|
||
|
ynext=y+ymov[k];
|
||
|
|
||
|
if(issafe(xnext,ynext,sol))
|
||
|
{
|
||
|
sol[xnext][ynext]=mov;
|
||
|
|
||
|
if(solve(xnext,ynext,mov+1,sol,xmov,ymov)==true)
|
||
|
return true;
|
||
|
else
|
||
|
sol[xnext][ynext]=-1;
|
||
|
}
|
||
|
}
|
||
|
return false;
|
||
|
}
|
||
|
int main()
|
||
|
{
|
||
|
//initialize();
|
||
|
|
||
|
int sol[n][n];
|
||
|
int i,j;
|
||
|
for(i=0;i<n;i++)
|
||
|
for(j=0;j<n;j++)
|
||
|
sol[i][j]=-1;
|
||
|
|
||
|
int xmov[8] = { 2, 1, -1, -2, -2, -1, 1, 2 };
|
||
|
int ymov[8] = { 1, 2, 2, 1, -1, -2, -2, -1 };
|
||
|
sol[0][0]=0;
|
||
|
|
||
|
bool flag=solve(0,0,1,sol,xmov,ymov);
|
||
|
if(flag==false)
|
||
|
cout<<"solution doesnot exist \n";
|
||
|
else
|
||
|
{
|
||
|
for(i=0;i<n;i++)
|
||
|
{
|
||
|
for(j=0;j<n;j++)
|
||
|
cout<<sol[i][j]<<" ";
|
||
|
cout<<"\n";
|
||
|
}
|
||
|
}
|
||
|
}
|