走迷宫问题总结

1、判断一个迷宫是否有出口

这个题目是我自己编的,leetcode上并没有这样的题目。为了锻炼自己的DFS,这个题目应该还是比较简单的,用深搜就可以完成,和之前做的max area of island有异曲同工之妙。

poll出迷宫问题:

如图所示的迷宫,0代表可以走,1代表有墙。要求从左上角到右下角是否有一条路可以走完。如何判断这个迷宫内是否有路。代码如下:

 1 boolean res = false;
 2     int[] dest;
 3     int[][] grid;
 4     boolean[][] visited;
 5     public boolean can(int[][] grid, int[] start, int[] dest){
 6         boolean[][] visited = new boolean[grid.length][grid[0].length];
 7         this.dest = dest;
 8         this.grid = grid;
 9         this.visited = visited;
10         helper(start[0],start[1]);
11         return res;
12     }
13
14     private void helper(int i, int j) {
15         if ( i == dest[0] && j == dest[1] ) res=true;
16         visited[i][j] = true;
17         if ( cango(i-1,j) ) helper(i-1,j);
18         if ( cango(i+1,j) ) helper(i+1,j);
19         if ( cango(i,j-1) ) helper(i,j-1);
20         if ( cango(i,j+1) ) helper(i,j+1);
21     }
22
23     public boolean cango(int i, int j){
24         if ( i < 0 || j < 0 || i >= grid.length || j >= grid.length) return false;
25         if ( grid[i][j] == 1 || visited[i][j] ) return false;
26         return true;
27     }

start数组时起始位置,end数组是终止位置。注意visited数组必不可少,记录走过的位置,已经走过的就不能再走了,否则就会陷入死循环。

这里先用一个cango函数来判断下一步是否可走,其实可以进行合并,简化一下:

 1     boolean res = false;
 2     int[] dest;
 3     int[][] grid;
 4     boolean[][] visited;
 5     public boolean can(int[][] grid, int[] start, int[] dest){
 6         boolean[][] visited = new boolean[grid.length][grid[0].length];
 7         this.dest = dest;
 8         this.grid = grid;
 9         this.visited = visited;
10         newhelper(start[0],start[1]);
11         return res;
12     }
13
14     private void newhelper(int i, int j ){
15         if ( i < 0 || j < 0 || i >= grid.length || j >= grid.length) return ;
16         if ( grid[i][j] == 1 || visited[i][j] ) return ;
17         if ( i == dest[0] && j == dest[1] ) res=true;
18         visited[i][j] = true;
19         newhelper(i-1,j);
20         newhelper(i+1,j);
21         newhelper(i,j-1);
22         newhelper(i,j+1);
23     }

我自己测试了几组情况,是正确的。不知道其他的情况是不是正确。

2、记录迷宫正确路径

现在问题变成这样,首先判断迷宫中能否有正确的道路,如果有的话,找出最短的那个道路。

因为要保存道路,所以一定要用一个数据结构来保存路径,栈是最好的。因为栈后进先出的特性,使得栈很适合数据的迭代。这里用两个栈来简单做一下,第一个栈stack1保存节点的行,第二个栈保存节点的列,两个栈就确定一个节点。

因为找的是最短路径,所以可以使用BFS算法。

原文地址:https://www.cnblogs.com/boris1221/p/9368644.html

时间: 2024-08-30 08:03:08

走迷宫问题总结的相关文章

NYOJ306 走迷宫(dfs+二分搜索)

题目描述 http://acm.nyist.net/JudgeOnline/problem.php?pid=306 Dr.Kong设计的机器人卡多非常爱玩,它常常偷偷跑出实验室,在某个游乐场玩之不疲.这天卡多又跑出来了,在SJTL游乐场玩个不停,坐完碰碰车,又玩滑滑梯,这时卡多又走入一个迷宫.整个迷宫是用一个N * N的方阵给出,方阵中单元格中填充了一个整数,表示走到这个位置的难度. 这个迷宫可以向上走,向下走,向右走,向左走,但是不能穿越对角线.走迷宫的取胜规则很有意思,看谁能更快地找到一条路

青蛙走迷宫问题(体力值)

题目: 青蛙走迷宫,1代表路通,0代表不通:起点是(0, 0),终点是(0,m - 1);青蛙每次向上走需要消耗体力值为3,向下走不消耗体力值,平走消耗体力值1:根据给定值判断青蛙是否可以根据初始值到达终点,并求出消耗体力值最少的路径: 举例: n = 4, m =4, p = 10(体力值) 4 4 10 1 0 0 1 1 1 0 1 0 1 1 1 0 0 1 1 则结果为:[[0, 0], [1, 0], [1, 1], [2, 1], [2, 2], [2, 3], [1, 3], [

深度优先算法——走迷宫的实现

深度优先搜索算法(Depth-First-Search),是搜索算法的一种.是沿着树的深度遍历树的节点,尽可能深的搜索树的分支.当节点v的所有边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点.这一过程一直进行到已发现从源节点可达的所有节点为止.如果还存在未被发现的节点,则选择其中一个作为源节点并重复以上过程,整个进程反复进行直到所有节点都被访问为止.属于盲目搜索. 深度优先搜索是图论中的经典算法,利用深度优先搜索算法可以产生目标图的相应拓扑排序表,利用拓扑排序表可以方便的解决很多相关的图

走迷宫

走迷宫 时限:1000ms 内存限制:10000K  总时限:3000ms 描述 判断是否能从迷宫的入口到达出口 输入 先输入两个整数表示迷宫的行数m和列数n,再输入口和出口的坐标,最后分m行输入迷宫,其中1表示墙,0表示空格每个数字之间都有空格. 输出 若能到达,则输出"Yes",否则输出"No",结果占一行. 输入样例 3 30 02 20 0 01 1 00 1 0 输出样例 Yes #include <iostream> using namesp

【老鼠走迷宫二】

/* 老鼠走迷宫二 有问题 */ #include <stdio.h> #include <stdlib.h> void visit(int ,int); int maze[9][9] = { {2, 2, 2, 2, 2, 2, 2, 2, 2}, {2, 0, 0, 0, 0, 0, 0, 0, 2}, {2, 0, 2, 2, 0, 2, 2, 0, 2}, {2, 0, 2, 0, 0, 2, 0, 0, 2}, {2, 0, 2, 0, 2, 0, 2, 0, 2}, {

算法:老鼠走迷宫问题

算法:老鼠走迷宫问题(初) [写在前面] 老鼠走迷宫问题的递归实现,是对递归思想的一种应用. [问题描述] 给定一个二维数组,数组中2表示墙壁,0表示通路,由此数组可展示为一个迷宫图.给定入口位置和出口位置,判断之间是否存在通路并显示出走出迷宫的道路. [代码] 对题目的描述部分 int migo[7][7]={ {2, 2, 2, 2, 2, 2, 2}, {2, 0, 0, 0, 0, 0, 2}, {2, 0, 2, 0, 2, 0, 2}, {2, 0, 0, 0, 0, 2, 2},

数据结构之深度优先搜索(走迷宫)

在此以走迷宫为例: 给定迷宫起点和终点,看能否到达:(xt,yt) void f(int x,int y){ if(x<0||x>21||y<0||y>21){//判断是否超出迷宫 return; } ch[x][y]='#'; for(i=0;i<4;i++){if(ch[x][y]=='.'){ if(x==xt+1&&y==yt+1){ flag=1; return ; } //四个方向 f(x,y+1); f(x,y-1); f(x+1,y); f(x

走迷宫——C++ 算法实现

这两个看了几个不错的走迷宫算法,然后按照自己的方式写了一个实现,代码如下: MyMazeMap.cpp 1 #include <iostream> 2 #include <Windows.h> 3 #include "MazeMap.h" 4 #include "Mazer.h" 5 using namespace std; 6 7 const int SUCCESS = 0; 8 9 int main() 10 { 11 int map[8

第四章 搜索(深度、广度搜索、全排列、走迷宫、再解炸弹人、宝岛探险、水管工游戏)

一.深度优先搜索DFS 深度优先搜索DFS的关键思想是:当下应该怎么做(每个方法都试一遍),这一步解决后,进入下一步,下一步的解决方法和这一步的解决方法是一样的 DFS的基本模型 void dfs(int step) { 判断边界 尝试每一种可能  for(i=1;i<=n;i++) { 继续下一步 dfs(step+1) } 返回 } 1.1全排列 1 //输入一个数n 2 //输出1-n的全排列 3 #include <stdio.h> 4 int n, book[10], a[10

【每天一道算法题】走迷宫

输入描述: 输入包含多组数据. 每组数据包含一个10*10,由“#”和“.”组成的迷宫.其中“#”代表墙:“.”代表通路. 入口在第一行第二列:出口在最后一行第九列. 从任意一个“.”点都能一步走到上下左右四个方向的“.”点. 输出描述: 对应每组数据,输出从入口到出口最短需要几步. 输入例子: #.#########........##........##........##........##........##........##........##........#########.#