深度优先搜索(DFS)
标签: 机试攻略 - 高分篇
学习人数: 18.4k


高清播放
赞赏支持

深度优先搜索的实现形式就是上一节的递归,如果把递归的流程画出来,那么我们可以得到一颗递归树,其实就是一个多叉树。

 

简单来说,BFS和DFS到底有什么区别呢?

对于一棵二叉树,
BFS就是二叉树的层次遍历,一层一层的扩展下去。
DFS就是二叉树的中序遍历,一条路走到底,然后回溯走第二条,直到所有路都走完。

大家需要注意的是,DFS一般情况下效率不如BFS,比如求DFS中的迷宫的最短路径使用DFS就会超时。

 

 

迷宫
题目描述:
小 A 同学现在被困在了一个迷宫里面,他很想从迷宫中走出来,他可以 向上、向下、向左、向右移动、每移动一格都需要花费 1 秒的时间,不能够走到 边界之外。假设小 A 现在的位置在 S,迷宫的出口在 E,迷宫可能有多个出口。 问小 A 想要走到迷宫出口最少需要花费多少秒?
输入描述:
有多组测试数据。
第一行输入两个正整数 H(0 < H <= 100)和 W(0 < W <= 100),分别表示迷
宫的高和宽。
接下来 H 行,每行 W 个字符(其中‘*’表示路,‘#’表示墙,‘S’表示小 A
的位置,‘E’表示迷宫出口)。
当 H 与 W 都等于 0 时程序结束。
输出描述:
输出小 A 走到迷宫出口最少需要花费多少秒,如果永远无法走到出口则输出“-1”。
输入样例#:
3 3
S*#
**#
#*E
0 0
输出样例#:
4
题目来源:
DreamJudge 1563

题目解析:直接使用深度优先搜索(DFS)模板。

 

超时代码(直接用DFS)

#include <bits/stdc++.h>  
using namespace std;  
  
const int maxn = 100 + 5;  
char mpt[maxn][maxn];  
int vis[maxn][maxn];  
int dir[4][2] = {1, 0, 0, -1, -1, 0, 0, 1};  
int ans;  
//使用深度优先搜索求解  
void dfs(int x, int y, int step) {  
    if (step >= ans) return;//一个小剪枝,当步数超过答案就不用继续  
    if (mpt[x][y] == 'E') {//找到终点  
        ans = min(ans, step);  
        return;  
    }  
    for (int i = 0; i < 4; i++) {//上下左右四个方向  
        int nx = x + dir[i][0];  
        int ny = y + dir[i][1];  
        if ((mpt[nx][ny] == '*' || mpt[nx][ny] == 'E')&&vis[nx][ny] == 0) {  
            vis[nx][ny] = 1;  
            dfs(nx, ny, step+1);  
            ...
登录查看完整内容


课后作业

掌握深度优先搜索(DFS)


登录后开始许愿

暂无评论,来抢沙发