美文网首页
[算法] - 8皇后问题(回溯法)

[算法] - 8皇后问题(回溯法)

作者: 夹胡碰 | 来源:发表于2021-03-18 16:03 被阅读0次

1. 问题

在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,如何求解?

2. 解题过程

该问题使用回溯法,其本质上是一种枚举法。这种方法从棋盘的第一行开始尝试摆放第一个皇后,摆放成功后,递归一层,再遵循规则在棋盘第二行来摆放第二个皇后。如果当前位置无法摆放,则向右移动一格再次尝试,如果摆放成功,则继续递归一层,摆放第三个皇后......

如果某一层看遍了所有格子,都无法成功摆放,则回溯到上一个皇后,让上一个皇后右移一格,再进行递归。如果八个皇后都摆放完毕且符合规则,那么就得到了其中一种正确的解法。

3. 代码

package com.jfp;

/**
 * @author jiafupeng
 * @desc   8皇后
 * @create 2021/3/17 14:54
 * @update 2021/3/17 14:54
 **/
public class Queen8 {

    static final int MAX_NUM = 8;
    int chessBoard[][] = new int[MAX_NUM][MAX_NUM];

    boolean check(int x, int y){
        for(int i = 0; i<y; i++){
            if(chessBoard[x][i] == 1){
                return false;
            }

            if(x-1-i >= 0 && chessBoard[x-1-i][y-1-i] == 1){
                return false;
            }

            if(x+1+i < MAX_NUM && chessBoard[x+1+i][y-1-i] == 1){
                return false;
            }
        }

        return true;
    }

    boolean settleQueen(int y){
        if(y == MAX_NUM){
            return true;
        }

        for(int i=0;i<MAX_NUM;i++){
            for(int x=0;x<MAX_NUM;x++){
                chessBoard[x][y] = 0;
            }

            if(check(i,y)){
                chessBoard[i][y] =1;
                if(settleQueen(y+1)){
                    return true;
                }
            }
        }

        return false;
    }

    void printChessBoard() throws InterruptedException {
        for(int j=0;j<MAX_NUM;j++){
            for(int i=0;i<MAX_NUM;i++){
                int a = chessBoard[i][j];
                Thread.sleep(1);
                if(a == 1){
                    System.err.print(a + " ");
                } else {
                    System.out.print(a + " ");
                }

            }
            System.out.println();
        }
    }

    public static void main(String[] args) throws InterruptedException {
        Queen8 queen8 = new Queen8();
        queen8.settleQueen(0);
        queen8.printChessBoard();
    }
}

4. 输出

5. 参考

  1. 漫画:什么是八皇后问题? - 小灰

相关文章

  • [算法] - 8皇后问题(回溯法)

    1. 问题 在8×8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线...

  • N皇后

    回溯法核心代码: n皇后问题回溯法

  • 数据结构与算法——基础篇(一)

    前置问题 经典问题与算法 8皇后问题(92种摆法)——回溯算法 字符串匹配问题——KMP算法(取代暴力匹配) 汉诺...

  • 算法(11):回溯法

    今天补一下回溯法,别的不说,n皇后问题必须列出来才行~ 目录:算法:附录算法(1):递归算法(2):链表算法(3)...

  • 51. N-Queens

    题目分析 N 皇后问题 + 回溯法 代码

  • 重写算法:八皇后问题

    八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。 问题的内容是在国际象棋棋盘上(8*8),放置八个皇后并...

  • 算法:八皇后问题

    八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例。 问题的内容是在国际象棋棋盘上(8*8),放置八个皇后并...

  • 回溯法求解8皇后问题

    结果 解法:92调用次数:15720 完整代码

  • 八皇后问题

    问题描述: 八皇后问题,是一个古老而著名的问题,是回溯算法的典型案例:在8X8格的国际象棋棋盘上摆放八个皇后,使其...

  • LeetCode 51. N-Queens

    Leetcode : N-QueensDiffculty:Hard N皇后问题,对八皇后问题的扩展,典型的回溯法算...

网友评论

      本文标题:[算法] - 8皇后问题(回溯法)

      本文链接:https://www.haomeiwen.com/subject/yihecltx.html