用 Applet实现八皇后问题
用 Applet实现八皇后问题
我来解决一下放置问题:
皇后的走法有点象象棋里面的车,但是她比车牛X多了,能走斜线,所以放置的时候必须满足以下2点条件:
1。 2个棋子不能同时在同一行或同一列上
2。 2个旗子不能同时在左斜线和右斜线的方向上
以下是解决的方案:
public class Queen{
public static int SIZE = 8;
public static void main(String[] args){
int[] Queen = new int [SIZE];
int y = 0,x = 0,i = 0,j = 0,d = 0,t = 0;
Queen[0] = -1;
while(true){
for(x=Queen[y]+1;x<SIZE;x++){
for(i=0;i<y;i++){
j = Queen[i];
d = y-i;
if((j==x)||(j==x-d)||(j==x+d))
break;
}
if (i>=y)
break;
}
if (x == SIZE){
if (0==y){
System.out.println("排列完成!");
break;
}
Queen[y]=-1;
y--;
}
else {
Queen[y]=x;
y++;
if (y<SIZE)
Queen[y]=-1;
else {
System.out.println("\n" + ++t +':');
for(i=0;i<SIZE;i++){
for (j=0;j<SIZE;j++){
if(Queen[i] == j)
System.out.print("■ ");
else
System.out.print("□ ");
}
System.out.println();
}
y = SIZE -1;
}
}
}
}
}