题解 | #重建二叉树#

重建二叉树

https://www.nowcoder.com/practice/8a19cbe657394eeaac2f6ea9b0f6fcf6

# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param preOrder int整型一维数组 
# @param vinOrder int整型一维数组 
# @return TreeNode类
#
class Solution:
    def reConstructBinaryTree(self , preOrder: List[int], vinOrder: List[int]) -> TreeNode:
        # write code here
        n = len(preOrder)
        m = len(vinOrder)

        if n==0 or m==0:
            return None
        root = TreeNode(preOrder[0])
        for i in range(m):
            if preOrder[0]==vinOrder[i]:
                # 从i处将中序遍历和前序遍历 拆分成左右子树,递归操作
                leftpre = preOrder[1:i+1]   # 这里的 i+1 是因为要包括完整的子树
                leftvin = vinOrder[:i]
                root.left = self.reConstructBinaryTree(leftpre,leftvin)
                rightpre = preOrder[i+1:]   
                rightvin = vinOrder[i+1:]   # 这里的 i+1 是因为不包括根节点
                root.right = self.reConstructBinaryTree(rightpre,rightvin)
                break
        return root
  1. 前中后 序 意思是根节点遍历是从哪里开始
  2. 注意递归拆分的时候列表边界问题
  3. Python中是左闭右开

剑指offer刷题笔记 文章被收录于专栏

24秋招剑指offer刷题的笔记

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利 有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的 真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
面试尴尬现场
点赞 评论 收藏
分享
06-28 22:48
已编辑
广东金融学院 Java
小浪_Coding:学院本+这俩项目不是buff叠满了嘛
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务