【前言】
C++深度优先搜索(DFS)是一种使用递归或栈的算法,用于在图或树等数据结构中遍历所有可能的路径,直到找到目标节点或遍历完所有节点。
本文将尽量用平易近人的语言来介绍该算法,观看之前请先点赞加关注。
【原理】
深度优先搜索的基本思想是从一个起始节点开始,依次选择一个相邻节点进行探索。如果该节点未被访问过,则继续以该节点为起始节点进行探索。当所有相邻节点都被访问过或无相邻节点时,递归地回溯到上一个节点,再选择另一个未被访问过的相邻节点进行探索。这个过程一直进行,直到找到目标节点或所有节点都被访问过。
简单来说,就像是走迷宫,把每条路都走一遍知道找到出口。
大家可能还是不能理解,没关系下面我们将通过一道题来帮助理解。
【例题】
【题目】
题目描素:
一个n*m的网格迷宫,起点的坐标为(1,1)终点的坐标为(n,m),每个网格可能是障碍物用“1”来表示也可能是空地用“0”来表示。求能走出迷宫的路有几条(只能往上下左右四个方向走)。
输入格式:
- 第1行2个数n,m;
- 第2~n+1行,每行每个数表示地图。
输出格式:
- 一行能走出迷宫的路的条数。
输入样例:
3 4
0 0 0 0
1 0 1 0
0 1 0 0
输出样例:
1
【代码】
#include<bits/stdc++.h>
using namespace std;
int n,m,g[205][205],dx[4]={0,