DFS算法原理及其模板

DFS------深度优先遍历,与BFS有极大的相似性,代码模板也是如此,我们这里给出BFS的讲解回来再看DFS就简单的多了,而且DFS代码写起来比BFS更简洁。

BFS算法讲解https://blog.csdn.net/czt230610/article/details/151409412?fromshare=blogdetail&sharetype=blogdetail&sharerId=151409412&sharerefer=PC&sharesource=czt230610&sharefrom=from_link与BFS不同的是,DFS是在某一点处采取一条路走到黑直到不能走下去再返回,而BFS是到某一点时先把该的周围走一遍然后以这些点为起点重复此操作。此外,DFS用到了递归思想(可以借助二叉树遍历思想理解)

这里直接给出DFS模板

cpp 复制代码
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
void dfs(...,int i,int j)//...通常为题目给出的矩阵等结构
{
   
       ...[i][j]=... //遍历后的标记/修改
    
      for(int k=0;k<4;k++)
       {
         int x=i+dx[k],y=j+dy[k];
         if(x>=0&&x<m&&y>=0&&y<n&&...[x][y]==...//满足的条件)//m,n为数组的长度宽度
         {
            bfs(...,x,y);
         }
       }
     
  
}
相关推荐
ytttr87341 分钟前
matlab实现多标签K近邻(ML-KNN)算法
算法·机器学习·matlab
一招定胜负1 小时前
逻辑回归调优三板斧:参数调整、阈值设定、数据集平衡
算法·机器学习·逻辑回归
豆约翰1 小时前
Z字形扫描ccf
java·开发语言·算法
Salt_07281 小时前
DAY 35 文件的规范拆分和写法
python·算法·机器学习
风筝在晴天搁浅1 小时前
代码随想录 109.冗余连接Ⅱ
算法
业精于勤的牙1 小时前
浅谈:算法中的斐波那契数(三)
算法·职场和发展
ss2731 小时前
阻塞队列:三组核心方法全对比
java·数据结构·算法
小O的算法实验室1 小时前
2026年SEVC SCI2区,面向空地跨域无人集群的目标引导自适应路径规划方法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
Xの哲學1 小时前
Linux MAC层实现机制深度剖析
linux·服务器·算法·架构·边缘计算
埃伊蟹黄面2 小时前
算法 --- hash
数据结构·c++·算法·leetcode