// Yifi 2003 have fun! : )
//8 Queen 递归算法
//如果有一个Q 为 chess[i]=j;
//则不安全的地方是 k行 j位置,j+k-i位置,j-k+i位置
class Queen8{
static final int QueenMax = 8;
static int oktimes = 0;
static int chess[] = new int[QueenMax];//每一个Queen的放置位置
public static void main(String args[]){
for (int i=0;i placequeen(0);
System.out.println(" 八皇后共有"+oktimes+"个解法 made by yifi 2003");
}
public static void placequeen(int num){ //num 为现在要放置的行数
int i=0;
boolean qsave[] = new boolean[QueenMax];
for(;i
//下面先把安全位数组完成
i=0;//i 是现在要检查的数组值
while (i qsave[chess[i]]=false;
int k=num-i;
if ( (chess[i]+k >= 0) && (chess[i]+k < QueenMax) ) qsave[chess[i]+k]=false;
if ( (chess[i]-k >= 0) && (chess[i]-k < QueenMax) ) qsave[chess[i]-k]=false;
i++;
}
//下面历遍安全位
for(i=0;i if (qsave[i]==false)continue;
if (num chess[num]=i;
placequeen(num+1);
}
else{ //num is last one
chess[num]=i;
oktimes++;
System.out.println("这是第"+oktimes+"个解法 如下:");
System.out.println("第n行: 1 2 3 4 5 6 7 8");
for (i=0;i String row="第"+(i+1)+"行: ";
if (chess[i]==0);
else
for(int j=0;j row+="++";
int j = chess[i];
while(j System.out.println(row);
}
}
}
//历遍完成就停止
}
}
我做的一个此问题的优化算法。 请大家多多发表意见哦 :)
Mailto:yifi@tom.com">mailto:yifi@tom.com
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-961049/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/10752043/viewspace-961049/
八皇后问题递归解法
本文介绍了一种解决八皇后问题的递归算法,并通过Java实现。该算法通过逐行放置皇后并验证安全性来寻找所有可能的解决方案,展示了完整的代码实现及运行结果。
7041

被折叠的 条评论
为什么被折叠?



