首页 > 编程语言 >多叉树的DFS深度优先遍历,回溯法的基础算法之一

多叉树的DFS深度优先遍历,回溯法的基础算法之一

时间:2024-06-17 22:32:31浏览次数:23  
标签:子树 多叉树 DFS 访问 遍历 二叉树 节点

一、前言

多叉树一般用于解决回溯问题。
想必大家都学过二叉树,以及二叉树的深度优先遍历和广度优先遍历,我们思考:能不能将二叉树的DFS转化为多叉树的DFS?

二、多叉树的结构

多叉树的本质,就是一棵普通的树,比如下图:
如果忽略将来的变化,那么,这棵树可以认为是一个未满的4叉树。不满的4叉树


由于多叉树代码实现比较复杂,在此不介绍。

三、从二叉树看多叉树

二叉树是非常特殊的,每一个节点,它只有2个子节点。并且,这两个节点可以直接拿到,即:
left指向左子节点,right指向右子节点。通过left、right就可以拿到它的左右节点。
多叉树是更加普遍的树结构,它满足树的层序性,满足最多一个父节点的性质。

四、二叉树的DFS,为什么不适用于多叉树?【以中序遍历为例】

我们知道,二叉树遍历满足口诀:“节点,左子树,右子树”。
链接
二叉树中序遍历
如果为二叉树的节点,增加一条子树X,位于右子树的右边。
结构为【左子树,右子树,X子树】
此时,使用中序遍历的口诀,我们发现,子树X遍历不到。【每一层子树X都遍历不到】。

五、解决多叉树遍历问题

多叉树遍历问题的关键在于,由于语句的次序性,每一次只能访问一个节点。
解释:二叉树的递归函数A中,访问节点值的操作,只发生一次,然后将访问左右子节点值的操作,交给子递归函数A’。
即使多出一个子树X,也不会改变语句的次序性。
解决方案:二叉树访问节点Node后,将左右子节点的访问交给子递归函数,那么,也可以把X子树的访问,同样交给子递归函数。
伪代码

void function(Node root){
	// 如果节点为null,返回
	if(node == null) return;
	
	// 访问节点
	print(root.val);
	
	//依次访问左子、右子和X子树
	function(root.left);
	function(root.right);
	function(root.X);
}

做完这一步,相信你对解决其它的多叉树遍历问题也有所了解。
然而,新问题出现了:
function函数,有指向性,直接拿到多叉树的第i个子树,然后遍历。
对于普遍的二叉树,这是没法做到的。

六、解决普遍多叉树,无指向性问题的两种方案

第一,定义节点顺序

既然无指向性,最简单的方案就是提供指向性。
比如对于4叉树,定义为:
第一个子节点fir,
第二个sec,
第三个thi,
第四个four。
这样,访问时就可以依次访问了。
当然,这种解决方案,不适用于外部复杂情况


第二,不考虑顺序,直接遍历子节点集合

如果多叉树提供一种方法,能够返回子节点集合。
那么,我们可以使用List存储子节点集合。
然后用foreach方法,遍历所有子树。
这种方案,使用时不考虑节点间的顺序性。

七、结语

我是蚊子码农,如有补充或者疑问,欢迎在评论区留言。个人的知识体系可能没有那么完善,希望各位多多指正,谢谢大家。

标签:子树,多叉树,DFS,访问,遍历,二叉树,节点
From: https://blog.csdn.net/weixin_62411896/article/details/139753721

相关文章

  • Java数组 详解(初始化 格式 索引 地址值 遍历 …)
    数组什么是数组?数组指的是一种容器可以用来存储同种数据类型的多个值小结:数组指的是一种容器可以用来存储同种数据类型的多个值//数组容器在存储数据的时候需要结合隐式转换考虑//例如int类型的数组容器( byte short int )//例如double类型的数组容器......
  • 开发一个python工具,pdf转图片,并且截成单个图片,然后修整没用的白边及循环遍历文件夹全
    今天推荐一键款本人开发的pdf转单张图片并截取没有用的白边工具一、开发背景:业务需要将一个pdf文件展示在前端显示,但是基于各种原因,放弃了h5使用插件展示原因有多个,文件资源太大加载太慢、pdf展示兼容性问题、pdf展示效果不好、pdf字体有时缺失等等,所以将项目中的协议等,全部由p......
  • 6.16-二叉树的层序遍历~
    429.N叉树的层序遍历题意描述:给定一个N叉树,返回其节点值的层序遍历。(即从左到右,逐层遍历)。例如,给定一个3叉树:返回其层序遍历:[[1],[3,2,4],[5,6]]思路:AC代码:classSolution{public:vector<vector<int>>levelOrder(Node*root){queue<No......
  • 05-5.3.1_1 二叉树的先中后序遍历
    ......
  • 5.3.1_2 二叉树的层次遍历
    ......
  • 【数据结构】遍历二叉树(递归思想)-->赋源码
    欢迎来到我的Blog,点击关注哦......
  • 「一个wfuzz应用案例」拿到目录遍历漏洞后用wfuzz爆破
    ┌──(root㉿kali)-[~]└─#wfuzz-uhttp://XXX.XXX.XXX.XXX/mailinspector/public/loader.php?path=../../../../../../..FUZZ-w~/weapons/http-payloads/linux_dir.txt--hl0*********************************************************Wfuzz3.1.0-TheWebFuzzer......
  • 6.14-二叉树遍历
    题目分类题目分类大纲如下:二叉树的种类在我们解题过程中二叉树有两种主要的形式:满二叉树和完全二叉树。满二叉树满二叉树:如果一棵二叉树只有度为0的结点和度为2的结点,并且度为0的结点在同一层上,则这棵二叉树为满二叉树。如图所示:这棵二叉树为满二叉树,也可以说深度为k,有......
  • 6.14BFS,DFS
    7-1列出联通集给定一个有N个顶点和E条边的无向图,请用DFS和BFS分别列出其所有的连通集。假设顶点从0到N−1编号。进行搜索时,假设我们总是从编号最小的顶点出发,按编号递增的顺序访问邻接点。输入格式:输入第1行给出2个整数N(0<N≤10)和E,分别是图的顶点数和边数。随后E行,每行给出......
  • MySQL 游标遍历每一行数据做处理。
     delimiter$$--分隔标记CREATEPROCEDUREprocess_test()begin--声明变量declareSuoshuQY_pvarchar(255);declaredoneint;declarecurcursorforSELECTSuoshuQYasSuoshuQY_pFROMdiy_cabinet_listWHEREIsDeleted=0;declareco......