【算法日常】二叉树常用遍历方法(二叉树,树,算法,编程语言)

时间:2024-05-02 18:23:18 作者 : 石家庄SEO 分类 : 编程语言
  • TAG :

二叉树的遍历

本篇算一个资料整理,就是二叉树遍历方法,有先序遍历(PreOrder)、中序遍历(InOrder)、后序遍历(PostOrder)、广度优先遍历二叉树(breadth_first_search)、深度优先遍历(depth_first_search)

示例遍历二叉树:
【算法日常】二叉树常用遍历方法

二叉树节点格式:

class TreeNode: def __init__(self, val): self.val = val self.left = self.right = None

1. 先序遍历 PreOrder

先遍历根节点,再遍历左子树,最后遍历右子树

def pre_order(root: TreeNode) -> list: if not root: return [] return [root.val] + pre_order(root.left) + pre_order(root.right)#### 遍历结果## [4, 2, 1, 3, 6, 5, 7]

2. 中序遍历 InOrder

先遍历左子树,再遍历根节点,最后遍历右子树,

def in_order(root: TreeNode) -> list: if not root: return [] return in_order(root.left) + [root.val] + in_order(root.right)#### 遍历结果## [1, 2, 3, 4, 5, 6, 7]

3. 后序遍历

先遍历左子树,再遍历右子树,最后遍历根节点

def post_order(root: TreeNode) -> list: if not root: return [] return post_order(root.left) + post_order(root.right) + [root.val]#### 遍历结果## [1, 3, 2, 5, 7, 6, 4]

4. 广度遍历二叉树 breadth-first-search

按照层级遍历二叉树

import collectionsdef breadth_first_search(root: TreeNode) -> list: """ 这个只是二叉树的广度优先遍历,和图的广度优先不同,返回二叉树的遍历顺序 :param root: TreeNode :return: list """ if not root: return [] queue = collections.deque() # 申请一个双端队列 queue.append(root) result = [] # visited = set(root) # 因为是树的结构,所以只要向下走不会存在重复的情况 while queue: level_size = len(queue) for _ in range(level_size): node = queue.popleft() # 这里从左边出了,下面加入的时候就要加到末尾,若是从右边出,则下面从左边push进去 result.append(node.val) if node.left: queue.append(node.left) if node.right: queue.append(node.right) return result### 输出结果## [4, 2, 6, 1, 3, 5, 7]

5. 深度遍历二叉树 depth-first-search

是一种用于遍历或搜索树或图的算法。 沿着树的深度遍历树的节点,尽可能深的搜索树的分支。 当节点v的所在边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点。 这一过程一直进行到已发现从源节点可达的所有节点为止

def depth_first_search(root: TreeNode, result=[]) -> list: """ 二叉树广度优先遍历,返回广度遍历顺序 :param root: :param result: :return: """ if not root: return [] result.append(root.val) depth_first_search(root.left, result) depth_first_search(root.right, result) return result### 输出结果## [4, 2, 1, 3, 6, 5, 7]
 </div> <div class="zixun-tj-product adv-bottom"></div> </div> </div> <div class="prve-next-news">
本文:【算法日常】二叉树常用遍历方法的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Django4.2_templates之各种标签的用法讲解下一篇:

9 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18