Python实现的二叉树的先序、中序、后序遍历示例

一、先序、中序、后序遍历的次序:

创建好一棵二叉树后,可以按照一定的顺序对树中所有的元素进行遍历。按照先左后右,树
的遍历方法有三种:先序遍历、中序遍历和后序遍历。
其中,先序遍历的次序是:如果二叉树不为空,则访问根节点,然后访问左子树,最后访问右
子树;否则,程序退出。
中序遍历的次序是:如果二叉树不为空,则先访问左子树,然后访问根节点,最后访问右子树;
否则,程序退出。
后序遍历的次序是:如果二叉树不为空,则先访问左子树,然后访问右子树,最后访问根节点。

二、示例所用的二叉树图:

三、示例代码:

class BinaryTree:                           # 创建一个二叉树节点的类,节点中定义三个属性,
    def __init__(self, elem):                # 分别为 elem 本身的值,还有 lchild 左孩子和rchild 右孩子
        self.elem = elem
        self.lchild = None
        self.rchild = None

    def insert_left(self, elem):            # 向左子树插入节点
        self.lchild = BinaryTree(elem)
        return self.lchild

    def insert_right(self, elem):           # 向右子树插入节点
        self.rchild = BinaryTree(elem)
        return self.rchild

    def show(self):                         # 输出节点数据
        print(self.elem)


def preorder(node):                         # 先序遍历函数
    if node.elem:
        node.show()
        if node.lchild:
            preorder(node.lchild)
        if node.rchild:
            preorder(node.rchild)


def inorder(node):                          # 中序遍历函数
    if node.elem:
        if node.lchild:
            inorder(node.lchild)
        node.show()
        if node.rchild:
            inorder(node.rchild)


def postorder(node):                        # 后序遍历函数
    if node.elem:
        if node.lchild:
            postorder(node.lchild)
        if node.rchild:
            postorder(node.rchild)
        node.show()


if __name__ == '__main__':
    Root = BinaryTree('Root')
    a = Root.insert_left('A')
    c = a.insert_left('C')
    d = a.insert_right('D')
    f = d.insert_left('F')
    g = d.insert_right('G')
    b = Root.insert_right('B')
    e = b.insert_right('E')
    print('binary tree Pre-traversal:')
    preorder(Root)
    print('binary tree In-traversal:')
    inorder(Root)
    print('binary tree Post-traversal:')
    postorder(Root)

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-07 22:22:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-07 22:22:02       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-07 22:22:02       82 阅读
  4. Python语言-面向对象

    2023-12-07 22:22:02       91 阅读

热门阅读

  1. 什么是游戏原画?如何学游戏原画?

    2023-12-07 22:22:02       68 阅读
  2. git报错WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!

    2023-12-07 22:22:02       65 阅读
  3. 【微服务常识】

    2023-12-07 22:22:02       63 阅读
  4. Python作业答疑_6.22~6.25

    2023-12-07 22:22:02       51 阅读
  5. Spring中MultipartFile和File转换

    2023-12-07 22:22:02       46 阅读
  6. 一次对黑域基地的手机端界面适配

    2023-12-07 22:22:02       57 阅读
  7. 【小程序】小程序开发教程入门到精通

    2023-12-07 22:22:02       48 阅读
  8. vsto 用‘解决科学计数法显示的问题

    2023-12-07 22:22:02       59 阅读
  9. HTTP请求方法

    2023-12-07 22:22:02       52 阅读