Java实现走迷宫回溯算法

时间:2022-09-04 22:07:42

以一个m×n的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍。设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路,或得出没有通路的结论。
(1) 根据二维数组,输出迷宫的图形。
(2) 探索迷宫的四个方向:right为向右,down向下,left向左,up向上,输出从入口到出口的行走路径。

例子:
左上角(1,1)为入口,右下角(8,9)为出口。

Java实现走迷宫回溯算法

可使用回溯方法,即从入口出发,顺着某一个方向进行探索,若能走通,则继续往前进;否则沿着原路退回,换一个方向继续探索,直至出口位置,求得一条通路。假如所有可能的通路都探索到而未能到达出口,则所设定的迷宫没有通路。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
import java.util.*;
 
class position{
  public position(){
 
  }
 
  public position(int row, int col){
    this.col = col;
    this.row = row;
  }
 
  public string tostring(){
    return "(" + row + " ," + col + ")";
  }
 
  int row;
  int col;
}
 
class maze{
  public maze(){
    maze = new int[15][15];
    stack = new stack<position>();
    p = new boolean[15][15];
  }
 
  /*
   * 构造迷宫
   */
  public void init(){
    scanner scanner = new scanner(system.in);
    system.out.println("请输入迷宫的行数");
    row = scanner.nextint();
    system.out.println("请输入迷宫的列数");
    col = scanner.nextint();
    system.out.println("请输入" + row + "行" + col + "列的迷宫");
    int temp = 0;
    for(int i = 0; i < row; ++i) {
      for(int j = 0; j < col; ++j) {
        temp = scanner.nextint();
        maze[i][j] = temp;
        p[i][j] = false;
      }
    }
  }
 
  /*
   * 回溯迷宫,查看是否有出路
   */
  public void findpath(){
    // 给原始迷宫的周围家一圈围墙
    int temp[][] = new int[row + 2][col + 2];
    for(int i = 0; i < row + 2; ++i) {
      for(int j = 0; j < col + 2; ++j) {
        temp[0][j] = 1;
        temp[row + 1][j] = 1;
        temp[i][0] = temp[i][col + 1] = 1;
      }
    }
    // 将原始迷宫复制到新的迷宫中
    for(int i = 0; i < row; ++i) {
      for(int j = 0; j < col; ++j) {
        temp[i + 1][j + 1] = maze[i][j];
      }
    }
    // 从左上角开始按照顺时针开始查询
 
    int i = 1;
    int j = 1;
    p[i][j] = true;
    stack.push(new position(i, j));
    while (!stack.empty() && (!(i == (row) && (j == col)))) {
 
      if ((temp[i][j + 1] == 0) && (p[i][j + 1] == false)) {
        p[i][j + 1] = true;
        stack.push(new position(i, j + 1));
        j++;
      } else if ((temp[i + 1][j] == 0) && (p[i + 1][j] == false)) {
        p[i + 1][j] = true;
        stack.push(new position(i + 1, j));
        i++;
      } else if ((temp[i][j - 1] == 0) && (p[i][j - 1] == false)) {
        p[i][j - 1] = true;
        stack.push(new position(i, j - 1));
        j--;
      } else if ((temp[i - 1][j] == 0) && (p[i - 1][j] == false)) {
        p[i - 1][j] = true;
        stack.push(new position(i - 1, j));
        i--;
      } else {
        stack.pop();
        if(stack.empty()){
          break;
        }
        i = stack.peek().row;
        j = stack.peek().col;
      }
 
    }
 
    stack<position> newpos = new stack<position>();
    if (stack.empty()) {
      system.out.println("没有路径");
    } else {
      system.out.println("有路径");
      system.out.println("路径如下:");
      while (!stack.empty()) {
        position pos = new position();
        pos = stack.pop();
        newpos.push(pos);
      }
    }
 
    /*
     * 图形化输出路径
     * */
 
    string resault[][]=new string[row+1][col+1];
    for(int k=0;k<row;++k){
      for(int t=0;t<col;++t){
        resault[k][t]=(maze[k][t])+"";
      }
    }
    while (!newpos.empty()) {
      position p1=newpos.pop();
      resault[p1.row-1][p1.col-1]="#";
 
    }
 
    for(int k=0;k<row;++k){
      for(int t=0;t<col;++t){
        system.out.print(resault[k][t]+"\t");
      }
      system.out.println();
    }
 
 
  }
 
  int maze[][];
  private int row = 9;
  private int col = 8;
  stack<position> stack;
  boolean p[][] = null;
}
 
class hello{
  public static void main(string[] args){
    maze demo = new maze();
    demo.init();
    demo.findpath();
  }
}

运行示例:

请输入迷宫的行数
3
请输入迷宫的列数
3
请输入3行3列的迷宫
0 1 1
0 0 1
1 0 0

有路径
路径如下:

Java实现走迷宫回溯算法

请输入迷宫的行数
9
请输入迷宫的列数
8
请输入9行8列的迷宫
0 0 1 0 0 0 1 0
0 0 1 0 0 0 1 0
0 0 1 0 1 1 0 1
0 1 1 1 0 0 1 0
0 0 0 1 0 0 0 0
0 1 0 0 0 1 0 1
0 1 1 1 1 0 0 1
1 1 0 0 0 1 0 1
1 1 0 0 0 0 0 0

有路径
路径如下:

Java实现走迷宫回溯算法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/u013474436/article/details/47977867