• Python算法——树的重建


    Python中的树的重建算法详解

    树的重建(Tree Reconstruction)是一种从给定的遍历序列中恢复原树结构的算法。在本文中,我们将讨论树的重建问题以及常见的重建算法,包括先序遍历和中序遍历序列重建二叉树,以及层序遍历序列重建二叉树。我们将提供Python代码实现,并详细说明每个算法的原理和步骤。

    1. 先序遍历和中序遍历序列重建二叉树

    给定一个二叉树的先序遍历序列和中序遍历序列,我们可以通过递归地进行树的重建。先序遍历序列的第一个元素为根节点,在中序遍历序列中找到该元素,将其分为左子树和右子树,然后递归对左右子树进行同样的操作。

    class TreeNode:
        def __init__(self, value):
            self.val = value
            self.left = None
            self.right = None
    
    def build_tree(preorder, inorder):
        if not preorder or not inorder:
            return None
        
        root_val = preorder[0]
        root = TreeNode(root_val)
        
        index = inorder.index(root_val)
        
        root.left = build_tree(preorder[1:index + 1], inorder[:index])
        root.right = build_tree(preorder[index + 1:], inorder[index + 1:])
        
        return root
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    2. 层序遍历序列重建二叉树

    给定一个二叉树的层序遍历序列,我们可以使用队列来逐层构建树结构。队列中的每个元素代表一个树节点,我们按照层序遍历的顺序依次将节点加入队列,并根据队列中的顺序建立树的连接关系。

    from collections import deque
    
    def build_tree_level_order(level_order):
        if not level_order:
            return None
        
        root = TreeNode(level_order[0])
        queue = deque([root])
        i = 1
        
        while i < len(level_order):
            current = queue.popleft()
            
            left_val = level_order[i]
            i += 1
            if left_val is not None:
                current.left = TreeNode(left_val)
                queue.append(current.left)
            
            right_val = level_order[i]
            i += 1
            if right_val is not None:
                current.right = TreeNode(right_val)
                queue.append(current.right)
        
        return root
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    示例

    示例1:先序遍历和中序遍历序列重建二叉树
    preorder = [3, 9, 20, 15, 7]
    inorder = [9, 3, 15, 20, 7]
    
    root = build_tree(preorder, inorder)
    
    # 验证重建的树
    def inorder_traversal(root):
        if root is not None:
            inorder_traversal(root.left)
            print(root.val, end=" ")
            inorder_traversal(root.right)
    
    print("Inorder Traversal of Reconstructed Tree:")
    inorder_traversal(root)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    输出结果:

    Inorder Traversal of Reconstructed Tree:
    9 3 15 20 7 
    
    • 1
    • 2
    示例2:层序遍历序列重建二叉树
    level_order = [3, 9, 20, None, None, 15, 7]
    
    root_level_order = build_tree_level_order(level_order)
    
    # 验证重建的树
    def inorder_traversal_level_order(root):
        if root is not None:
            inorder_traversal_level_order(root.left)
            print(root.val, end=" ")
            inorder_traversal_level_order(root.right)
    
    print("Inorder Traversal of Reconstructed Tree from Level Order:")
    inorder_traversal_level_order(root_level_order)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    输出结果:

    Inorder Traversal of Reconstructed Tree from Level Order:
    9 3 15 20 7 
    
    • 1
    • 2

    以上两个示例演示了树的重建算法的使用,分别使用先序遍历和中序遍历序列,以及层序遍历序列重建二叉树。这些算法在树的序列化和反序列化中起到关键作用,通过理解其原理和实现,您将能够更好地处理树结构的相关问题。

  • 相关阅读:
    谈谈什么是数据质量管理
    [附源码]计算机毕业设计JAVA 停车场管理系统
    Java项目:SSM共享汽车租赁平台
    自监督学习和对比学习举例讲解(附代码)
    【生活】罗曼·罗兰语录
    【28】c++设计模式——>观察者模式(1)
    Flume实时采集mysql数据到kafka中并输出
    从React源码来学hooks是不是更香呢
    深度估计论文梳理
    网络安全筑基篇——SQL注入
  • 原文地址:https://blog.csdn.net/weixin_46178278/article/details/134417289