论坛: 编程破解 标题: 8*8棋盘中马的遍历程序 复制本贴地址    
作者: ziaichen [ziaichen]    论坛用户   登录
#include<stdio.h>
int deltai[]={2,1,-1,-2,-2,-1,1,2};
int deltaj[]={1,2,2,1,-1,-2,-2,-1};
int board[8][8];
int exitn(int i,int j,int s,int a[])
{
int i1,j1,k,count;
for(count=k=0;k<8;k++)
{
i1=i+deltai[(s+k)%8];
j1=j+deltaj[(s+k)%8];
if(i1>=0&&i1<8&&j1>=0&&j1<8&&board[i1][j1]==0)
a[count++]=(s+k)%8;
}
return count;
}
int next(int i,int j,int s)
{
int m,k,kk,min,a[8],b[8],temp;
m=exitn(i,j,s,a);
if(m==0)
return -1;
for(min=9,k=0;k<m;k++)
{
temp=exitn(i+deltai[a[k]],j+deltaj[a[k]],s,b);
if(temp<min)
{
min=temp;
kk=a[k];
}
}
return kk;
}
void main()
{
int sx,sy,i,j,step,no,start;
for(sx=0;sx<8;sy++)
for(sy=0;sy<8;sy++)
{
start=0;
do
{
for(i=0;i<8;i++)
for(j=0;j<8;j++)
board[i][j]=0;
board[sx][sy]=1;
i=sx;j=sy;
for(step=2;step<=64;step++)
{
if((no=next(i,j,start))==-1)
break;
i+=deltai[no];
j+=deltaj[no];
board[i][j]=step;
}
if(step>64)
break;
start++;
}while(1);
for(i=0;i<8;i++)
{
for(j=0;j<8;j++)
printf("%4d",board[i][j]);
printf("\n\n");
}
scanf("%*c");
}
}

感觉程序不是很好,哪位能帮帮忙,把这个程序优化一下?/
谢谢!



地主 发表时间: 04-06-02 09:22

回复: 286 [unique]   版主   登录
可以考虑采用递归的方法,这样效率虽然不高。但可以穷举。

B1层 发表时间: 04-06-02 11:39

回复: dyx [dyx]   论坛用户   登录
回溯

B2层 发表时间: 04-08-02 11:43

论坛: 编程破解

20CN网络安全小组版权所有
Copyright © 2000-2010 20CN Security Group. All Rights Reserved.
论坛程序编写:NetDemon

粤ICP备05087286号