⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 111.cpp

📁 马遍历的算法
💻 CPP
字号:
#include<iostream.h>
int i,sx[64]={0},sy[64]={0};
bool map[8][8];
bool f(int step,int way,int x,int y)
{
    
    if(way==1){x=x+2;y=y+1;}
    if(way==2){x=x+2;y=y-1;}
    if(way==3){x=x-2;y=y+1;}
    if(way==4){x=x-2;y=y-1;}
    if(way==5){x=x+1;y=y+2;}
    if(way==6){x=x+1;y=y-2;}
    if(way==7){x=x-1;y=y+2;}
    if(way==8){x=x-1;y=y-2;}
    if(x<0||y<0||x>=8||y>=8||map[x][y])return false;
    sx[step-1]=x;sy[step-1]=y;
	if(step==64)return true;
    map[x][y]=true;
    for(i=1;i<9;i++)
    {
        if(f(step+1,i,x,y))return true;
    }
	map[x][y]=false;
    return false;
}
main()
{
	int k;
	bool asdf;
	asdf=f(1,0,1,2);
	if(!asdf)
	{
		for(k=0;k<64;k++)cout<<"The "<<k+1<<" step:("<<sx[k]<<","<<sy[k]<<")"<<endl;
	}
	else cout<<"impossible"<<endl;

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -