首页 > 常见问答

二叉树的非递归遍历 二叉树的遍历算法实现为何要采用递归?

二叉树的遍历算法实现为何要采用递归?

数据结构中二叉树的定义是递归的,自然易懂。

二叉树的层次遍历不是递归的,而是使用队列。数据结构中二叉树的定义如下(不同于图论中树的定义):1。这是一个空集。2它由根节点及其左右子树组成,左右子树满足二叉树的定义。

花一晚上也无法理解二叉树的非递归遍历,我该继续学下去吗?

通常情况下,有必要花更多的时间。首先需要了解堆栈的操作和意义,还需要了解遍历二叉树的思想。有人用节点着色来编写非递归算法,即黑、灰、白三种颜色代表节点的状态,未被访问的节点为白色,未被访问的节点为灰色,被访问的节点为黑色。对于中间顺序遍历,除非访问了左子树,否则需要访问当前节点,所以依次沿左子树搜索,找到叶子后访问,然后退出右堆栈上的元素,并在右子树上执行相应的操作,直到堆栈为空。

二叉树的非递归遍历遍历二叉树口诀二叉树的遍历图解例题

二叉树的非递归遍历 二叉树的遍历算法实现为何要采用递归?

原文标题:二叉树的非递归遍历 二叉树的遍历算法实现为何要采用递归?,如若转载,请注明出处:https://www.saibowen.com/wenda/20846.html
免责声明:此资讯系转载自合作媒体或互联网其它网站,「赛伯温」登载此文出于传递更多信息之目的,并不意味着赞同其观点或证实其描述,文章内容仅供参考。