迷宫回溯

public class MiGongHuiSu{
    
    
    public static void main(String[] args){
    
    
        int[][] map = new int[8][7];

        for(int i=0; i<map.length; i++){
    
    
            map[i][0] = 1;
            map[i][6] = 1;
        }

        for(int i=0; i<7; i++){
    
    
            map[0][i] = 1;
            map[7][i] = 1;
        }
        map[3][2] = map[3][1] = 1;
        for(int i=0; i<map.length; i++){
    
    
            for(int j=0; j<map[i].length; j++){
    
    
                System.out.print(map[i][j] + "  ");
            }
            System.out.println("");
        }

        setWay(map, 1, 1);
        System.out.println("走迷宫的路径:");
        for(int i=0; i<map.length; i++){
    
    
            for(int j=0; j<map[i].length; j++){
    
    
                System.out.print(map[i][j] + "  ");
            }
            System.out.println("");
        }

    }
    //注:2表示已走过该路,1表示墙,0表示未走过
    public static boolean setWay(int[][] map, int i, int j){
    
    
        if(map[6][5] == 2){
    
    
            return true;
        }else{
    
    
            if(map[i][j] == 0){
    
    
                map[i][j] = 2;
                if(setWay(map, i+1, j)){
    
    //向下走能走通
                    return true;
                }else if(setWay(map, i, j+1)){
    
    //向右能走通
                    return true;
                }else if(setWay(map, i-1, j)){
    
    //向上能走通
                    return true;
                }else if(setWay(map, i, j-1)){
    
    //向左能走通
                    return true;
                }else{
    
    //说明该路走不通,是死路
                    map[i][j] = 3;
                    return false;
                }
            }else{
    
    //如果map[i][j]!=0,可能是1,2,3,其中1表示是墙,2表示已经走过这条路了,3表示死路
                return false;
            }
        }
    }
}
import java.util.Arrays;

public class MiGong {
    
    
    public static void main(String[] args) {
    
    
        int[][] map = new int[8][7];

        for(int i = 0; i < map.length; i++){
    
    
            map[i][0] = 1;
            map[i][6] = 1;
        }

        for(int i = 0; i < 7; i++){
    
    
            map[0][i] = 1;
            map[7][i] = 1;
        }
        map[3][2] = map[3][1] = 1;

        int[][] next = {
    
    {
    
    -1, 0}, {
    
    0, -1}, {
    
    1, 0}, {
    
    0, 1}};
        for(int i=0; i<map.length; i++){
    
    
            for(int j=0; j<map[i].length; j++){
    
    
                System.out.print(map[i][j] + "  ");
            }
            System.out.println("");
        }
        System.out.println("走迷宫:");
        dfs(map, next, 8, 7, 1, 1);
    }

    /**
     *
     * @param map 迷宫数组, 0表示该点可以走,1表示该点是障碍,2表示已走过。
     * @param next 下一步往哪移动
     * @param n 迷宫有多少行
     * @param m 迷宫有多少列
     * @param i 代表当前在哪一行
     * @param j 代表当前在哪一列
     */
    public static void dfs(int[][] map, int[][] next, int n, int m, int i, int j){
    
    
        map[i][j] = 2;
        if(i == n - 2 && j == m - 2){
    
    
            for(int[] arr : map){
    
    
                System.out.println(Arrays.toString(arr));
            }
            System.out.println("===========================");
            return;
        }
        for(int k = 0; k < 4; k++){
    
    
            int nextX = i + next[k][0];
            int nextY = j + next[k][1];
            if(nextX < 0 || nextX >= n || nextY < 0 || nextY >= n){
    
    
                continue;
            }
            if(map[nextX][nextY] == 0){
    
    
                //map[nextX][nextY] = 2;//可有可无
                dfs(map, next, n, m, nextX, nextY);
                map[nextX][nextY] = 0;
            }
        }
    }
}

猜你喜欢

转载自blog.csdn.net/weixin_46497503/article/details/112723975
今日推荐