s解决迷宫问题c++
时间: 2024-09-09 09:01:15 浏览: 40
解决迷宫问题是一个经典的计算机科学问题,通常通过深度优先搜索(Depth First Search, DFS)或广度优先搜索(Breadth First Search, BFS)算法来实现。在C++中,可以使用数组或二维字符矩阵来表示迷宫,其中0代表空地,1代表墙壁。
以下是使用DFS的一个基本思路:
```cpp
void dfs(int maze[][N], int start_row, int start_col, bool visited[]) {
// 验证当前位置是否有效
if (start_row < 0 || start_row >= N || start_col < 0 || start_col >= N || maze[start_row][start_col] == 1 || visited[start_row][start_col]) return;
// 标记当前位置已访问并递归遍历相邻未访问位置
visited[start_row][start_col] = true;
if (start_row > 0 && maze[start_row - 1][start_col] != 1) dfs(maze, start_row - 1, start_col, visited);
if (start_col < N - 1 && maze[start_row][start_col + 1] != 1) dfs(maze, start_row, start_col + 1, visited);
if (start_row < N - 1 && maze[start_row + 1][start_col] != 1) dfs(maze, start_row + 1, start_col, visited);
if (start_col > 0 && maze[start_row][start_col - 1] != 1) dfs(maze, start_row, start_col - 1, visited);
// 当回溯到起点时,标记终点
if (start_row == end_row && start_col == end_col) {
cout << "Path found!" << endl;
}
}
```
你可以调用`dfs`函数,传递迷宫、起始位置和一个布尔矩阵`visited`来跟踪已经访问过的节点,找到从起点到终点的路径。
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="-"
data:image/s3,"s3://crabby-images/10214/10214c21be157c7ee09c5af8793db42d5f2aee45" alt="-"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="-"
data:image/s3,"s3://crabby-images/e09fa/e09fa4d37aa4b8ac63bbefa75d17fdf661f74dab" alt="application/msword"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/e802a/e802a808507cc67c433d0f14f4478cfc18013243" alt="-"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/a328d/a328d6a6859eceb4fd8b0788ab1ea4dca20a7b0e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/48ecf/48ecfff65b0229a65d66a94d53c67b4ec0248998" alt="-"