《面试》---Python 实现二叉树结构以及相关遍历

来源:互联网 发布:佐治亚南方大学 知乎 编辑:程序博客网 时间:2024/05/16 11:15

第一部分
手动二叉树的构建

构建二叉树
a
b c
d f e
实际上是一个list
[a,[b,[d,[],[]],[f,[],[]]],[c,[],[e,[],[]]]]

# 构建根节点def BinaryTree(item):    return [item,[],[]]# 访问左右子数def getLeftChild(tree):    return tree[1]def getRightChild(tree):    return tree[2]# 插入左子树def insertLeft(tree,item):    leftSubtree = tree.pop(1)    # pop() 函数是 对原list去掉这个值,但是这个可以理解为取值    if leftSubtree:    # 如果原左子树节点存在的话,则插入节点,原节点,[]        tree.insert(1,[item,leftSubtree,[]])    else:    # 如果原左子树节点不存在的话,直接把节点当做节点插入 item,[],[]        tree.insert(1,[item,[],[]])    return tree# 插入右子树   同理左子树def insertRight(tree,item):    rightSubtree=tree.pop(2)    if rightSubtree:        tree.insert(2,[item,[],rightSubtree])    else:        tree.insert(2,[item,[],[]])    return tree#  根节点tree=BinaryTree('a')# 第一层insertLeft(tree,'b')insertRight(tree,'c')#  第二层insertLeft(getLeftChild(tree),'d')insertRight(getLeftChild(tree),'e')insertRight(getRightChild(tree),'f')print tree
原创粉丝点击