建立二叉樹和三種遍歷

二叉樹

建立和遍歷

# -*- coding:utf-8 -*-
class TreeNode:
    def __init__(self, x, left=None, right=None):
        self.val = x
        self.left = left
        self.right = right

    @staticmethod
    def before(self):
        """
        前序遍歷 根 左 右
        :param self:
        :return:
        """
        if not self:
            return
        print(self.val)
        self.before(self.left)
        self.before(self.right)

    @staticmethod
    def middle(self):
        """
        中序遍歷,左  根  右
        :param self:
        :return:
        """
        if not self:
            return
        self.middle(self.left)
        print(self.val)
        self.middle(self.right)

    @staticmethod
    def after(self):
        """
        右序遍歷 左  右  根
        :param self:
        :return:
        """
        if not self:
            return
        self.after(self.left)
        self.after(self.right)
        print(self.val)
    
        @staticmethod
    def depth(self):
        """
        層次遍歷
        :return:
        """
        if not self:
            return
        res, q = [],[]
        # 根節點入隊
        q.append(self)
        # 循環 q 隊列
        while q:
            # 取出第一個元素
            node = q.pop(0)
            # 把節點的值加到列表
            res.append(node.val)
            # 若是節點的左邊有節點,入隊
            if node.left:
                q.append(node.left)
            # 若是節點的右邊有節點,入隊
            if node.right:
                q.append(node.right)
        return res

    def __str__(self):
        return self.val


root = TreeNode(
    'A',
    TreeNode('B',
             TreeNode('D',
                      TreeNode('G')),
             ),
    TreeNode('C',
             TreeNode('E',
                      TreeNode('H')),
             TreeNode('F',
                      right=TreeNode('I'))
             )
)
# 驗證
# print(root)
# print(root.left)
# print(root.right)
# print(root.left.left)
# print(root.right.left)

# root.before(root)
# root.middle(root)
root.after(root)
print(root.depth(root))
相關文章
相關標籤/搜索