【前言】
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,0,-1,1},dy[4]={-1,1,0,0},ans=0;
int DFS(int x,int y){//x,y代表坐标
if(x!=n||y!=m){//没到终点继续搜索
for(int i=0;i<4;i++){//向四个方向移动
int xx=x+dx[i],yy=y+dy[i];
if(g[xx][yy]==0&&xx>0&&xx<=n&&yy>0&&yy<=m){//如果不出界且没障碍
g[xx][yy]=1;//标记已走,不然会在原地转圈
if(xx==n&&yy==m)ans++;//如果到达终点,条数加1
else DFS(xx,yy);//否则继续搜索
g[xx][yy]=0;//路径不止一条,要回溯
}
}
}
}
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)cin>>g[i][j];
g[i][j]=1;//起点标记已走
DFS(1,1);
cout<<ans;
return 0;
}
【模板】
从上面的例题可以得到深度优先搜索的代码模板
int DFS(……){
if(条件){
for(算符种数){
if(是否满足条件){
标记;
if(到达边界)……;
else DFS(……);
回溯;
}
}
}
}