【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,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值