python3递归建立二叉树

注意事项:

  1. 建树是遍历建树的,但是所给的list不一定是先序、后序、中序的结构,而是正常的广度优先遍历结构,这是可以使用2*i+1表示左孩子,2*i+2表示右孩子;或者使用Bfs遍历建树;
  2. 递归建树的时候,一定要注意,边界return的内容是什么,会不会对下次return产生影响;以及最后是否需要return root;同时注意整个减少的要求:比如,肯定list不能越界才对。
class TreeNode:
    def __init__(self, val: int):
        self.val = val
        self.left = None
        self.right = None


node = TreeNode
tree = [3, 5, 1, 6, 2, 0, 8, '+', '+', 7, 4]


def build(root, tree, i):
    if i < len(tree):
        if tree[i] == '+':
            return None
        root = TreeNode(tree[i])
        root.left = build(root.left, tree, 2 * i + 1)
        root.right = build(root.right, tree, 2 * i + 2)
        return root  # 这个return root还是十分关键的 不然被返回None以后怎么往上返回呢


root = build(None, tree, 0)
print(root)


def xian(root):
    if not root: return None  # 但是这个地方就是可以的,因为他是return None之后接着对return的结果进行判断
    print(root.val)
    xian(root.left)
    xian(root.right)


xian(root)

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值