public class Queen {
int count=0;
int max=8;
int[]array=new int[8];
public static void main(String args[]){
Queen queen=new Queen();
queen.check(0);
System.out.println(queen.count);
}
public void check(int n){
if (n==max){
count++;
print();
return;
}
for(int i=0;i<max;i++){
array[n]=i;
if(judge(n)){
check(n+1);
}
}
}
public boolean judge(int n){
for (int i=0;i<n;i++){
if (array[i]==array[n]||Math.abs(n-i)==Math.abs(array[i]-array[n])){
return false;
}
}
return true;
}
public void print(){
for (int i=0;i<max;i++){
System.out.print(array[i]);
}
System.out.println();
}
}
共勉!
八皇后问题的Java实现
这是一个使用Java编写的八皇后问题解决方案。代码通过递归实现,检查每一种放置皇后的可能性,并通过判断条件排除冲突。当所有皇后都成功放置时,计数器加一并打印解决方案。
5975

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



