骑士巡游问题

国际象棋中的马,从任何一个格子开始,是否可以找到一种走法,走遍全部的64个格子,并且要求已经走过的点不要重复地走,但不要求最后回到出发点

采用深度优先,递归调用。

软件结构
1)二维数组表示棋盘,map[m][n]
2)选择一个初始点(0,0)
3)从初始点开始跳跃,跳跃的方法是从当前格可跳跃到的所有方格之中任选一个跳入,如果跳到死胡同里,则退回选择其他未遍历的方格;如果跳满了所有的方格,则成功。
#include <iostream> 
#include <iomanip>  //I/O流控制头文件,setw()的头文件,setw(n) 设域宽为n个字符 
#define N 12        //定义一个宏并赋初值 
using namespace std; 
int b[N][N];    //定义全局性的二维数组保存步数 
bool a[N][N];   //记录某一点是否已经走过 
int num=0;      //记录方案数 
int dx[]={0,1,1,-1,-1,2,2,-2,-2};  
int dy[]={0,2,-2,2,-2,1,-1,1,-1};  //提供每一步的走法 
void solve(int i,int j,int k,bool&ok,int n)  //计算走法 
{
 int m,x1,y1,n1,n2; 
 bool t1,t2;    //布尔变量
 for(m=1;m<=8;m++) 
 { 
     x1=i+dx[m]; 
     y1=j+dy[m]; 
     t1=((x1>=0)&&(x1<n));  //判断x是否在棋盘内 
     t2=((y1>=0)&&(y1<n));  //判断y是否在棋盘内 
     if((t1==true)&&(t2==true)&&(a[x1][y1]==true)) 
	 { 
       a[x1][y1]=false;  //记录该点已经走过 
       b[x1][y1]=k; //k代表第几步
       if(k<n*n)    
	   { 
         solve(x1,y1,k+1,ok,n); 
	   } 
       else 
	   { 
         num++;     //方案数加一 
         ok=true; 
         cout<<"方案"<<num<<" :"<<endl; 
           for(n1=0;n1<n;n1++) 
		   { 
              for(n2=0;n2<n;n2++) 
			  {     
                cout<<setw(4)<<b[n1][n2]; //依次输出经过每一点时的步数 
			  } 
              cout<<endl; 
		   }                                //return; 
	   } 
       a[x1][y1]=true; 
	 } 
 } 
} 
int main() 
{	
   int i,j,row,col,n; 
   bool ok=false ; 
   cout<<"请输入n:";
   cin>>n; 
   for(i=0;i<n;i++) 
   { 
     for(j=0;j<n;j++) 
      a[i][j]=true; 
   } 
 
   cout<<"请输入起始位置的坐标:"; 
   cin>>row>>col; 
   b[row-1][col-1]=1;            //设置起始点 
   a[row-1][col-1]=false; 
   solve (row-1,col-1,2,ok,n);  //调用函数计算结果 
   if(!ok) 
   cout<<"从点("<<row<<","<<col<<")出发无法遍访棋盘的每一个位置"<<endl; 
   system("pause");
   return 0; 
}

  

posted @ 2015-05-11 20:30  LJJ洁儿  阅读(566)  评论(0编辑  收藏  举报