python21_面向对象编程 项目案例:二叉树的封装

二叉树的理解

二叉树的理解

在这里插入图片描述在这里插入图片描述

二叉树的实现

思路

  • 封装节点
  • 封装二叉树
  • 实现先序遍历
    基本思想:先访问根结点,再先序遍历左子树,最后再先序遍历右子树即根—左—右。
    在这里插入图片描述

代码

class Node(object):
    """封装 节点类"""
    def __init__(self, val=0, left=None, right=None):
        self.val = val
        self.left = left
        self.right = right

class BinaryTree(object):
    """封装 二叉树"""
    def __init__(self, root):
        self.root = root

    def pre_travel(self, root):
        """先序遍历: 根-左-右"""
        if (root != None):
            print(root.val, end=' ')
            self.pre_travel(root.left)
            self.pre_travel(root.right)

    def in_travel(self, root):
        """中序遍历: 左-根-右"""
        if (root != None):
            self.in_travel(root.left)
            print(root.val, end=' ')
            self.in_travel(root.right)

    def last_travel(self, root):
        """后序遍历: 左-右-根"""
        if (root!= None):
            self.last_travel(root.left)
            self.last_travel(root.right)
            print(root.val, end=' ')

if __name__ == '__main__':
    node1 = Node(1)
    node2 = Node(2)
    node3 = Node(3)
    node4 = Node(4)
    node5 = Node(5)
    node6 = Node(6)
    node7 = Node(7)
    node8 = Node(8)
    node9 = Node(9)
    node10 = Node(10)

    bt = BinaryTree(root=node1)
    node1.left = node2
    node1.right = node3
    node2.left = node4
    node2.right = node5
    node3.left = node6
    node3.right = node7
    node4.left = node8
    node4.right = node9
    node5.left = node10

    # 先序遍历
    bt.pre_travel(node1)    # 1 2 4 8 9 5 10 3 6 7 
    print()
    bt.in_travel(node1)     # 8 4 9 2 10 5 1 6 3 7
    print()
    bt.last_travel(node1)   # 8 9 4 10 5 2 6 7 3 1
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值