八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。高斯认为有76种方案。1854年在柏林的象棋杂志上不同的作者发表了40种不同的解,后来有人用图论的方法解出92种结果。
简单介绍回溯法思路,就是将所有的结果变成一棵树,从树的结点开始访问,采用深度优先策略,从树的根结点开始访问,如果满足条件,继续访问下一层,如果不满足条件,返回上一个结点,继续访问其它结点。重复操作。
首先,可归纳问题的条件为,8皇后之间需满足:
1.不在同一行上
2.不在同一列上
3.不在同一斜线上
4.不在同一反斜线上
代码如下:
class Eight{
//n皇后如何处理?n>=4
public static int count=0;
public static int n;
public static void main(String[] args){
n=8;