python 实现 二叉树

2年前 (2022) 程序员胖胖胖虎阿
277 0 0

条件:
array = [1,2,3,4,5,6,7,8,9,10]

# python实现二叉树的数据结果

class TreeNode(object):

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


class BinaTree(object):

    def __init__(self):
        self.root = None
        self.ls = []

    def add(self, val):
        node = TreeNode(val)
        if self.root == None:
            self.root = node
            self.ls.append(self.root)
        else:
            cur_node = self.ls[0]
            if cur_node.left == None:
                cur_node.left = node
                self.ls.append(cur_node.left)
            elif cur_node.right == None:
                cur_node.right = node
                self.ls.append(cur_node.right)
                self.ls.pop(0)

    def prescan(self, root):
        if root == None:
            return
        print(root.val)
        self.prescan(root.left)
        self.prescan(root.right)

if __name__ == "__main__":
    array = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
    bt = BinaTree()
    for val in array:
        bt.add(val)
    bt.prescan(bt.root)
 
版权声明:程序员胖胖胖虎阿 发表于 2022年9月12日 上午3:24。
转载请注明:python 实现 二叉树 | 胖虎的工具箱-编程导航

相关文章

暂无评论

暂无评论...