八皇后问题

Posted vector11248

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了八皇后问题相关的知识,希望对你有一定的参考价值。

import java.util.*;
import java.io.*;
import java.math.*;
public class Hello
{
    static int cnt =1;
     public static void main(String[] args) throws IOException
    {
        int n = 8;
        char[][] board = new char[n][n];
        for(int i=0;i<n;i++){
            for(int j=0;j<n;j++){
                    board[i][j] = ‘.‘;
            }

        }
        List<List<String>> res = new ArrayList<List<String>>();
        dfs(board,0,res);

        for (List<String > l:res) {
            for(String s:l)
                System.out.println(s);
            System.out.println(cnt);
            cnt++;
        }

        //System.out.println(res);
    }
    private static void dfs(char[][] board, int colIndex, List<List<String>> res){
        if(colIndex == board.length){
            res.add(construct(board)); return;
        }
        for(int i=0;i<board.length;i++){
            if(validate(board,i,colIndex)){
                board[i][colIndex] = ‘Q‘;
                dfs(board,colIndex+1,res);
                board[i][colIndex] = ‘.‘;
            }
        }

    }

    private  static  boolean validate(char[][] board,int x,int y){
        for(int i=0;i<board.length;i++){
            for(int j=0;j<y;j++){
                if(board[i][j] == ‘Q‘ && ( x+y ==i+j || x-y == i-j || x==i )){
                    return false;
                }
            }
        }
        return true;
    }

    public static List<String> construct(char[][] board){
        List<String> res = new LinkedList<String>();
        for(int i=0;i<board.length;i++){
            String s = new String(board[i]);
            res.add(s);
        }
        return res;
    }




}

 

以上是关于八皇后问题的主要内容,如果未能解决你的问题,请参考以下文章

八皇后,回溯与递归(Python实现)

基于WPF的八皇后简单应用程序

八皇后问题的遗传算法解法,c语言编写

八皇后问题

八皇后

八皇后问题