【C++】深度优先搜索DFS

【前言】

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(……);
              回溯;
           }
       }
    }
}

  • 10
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值