题解 | #输出二叉树的右视图#

输出二叉树的右视图

http://www.nowcoder.com/practice/c9480213597e45f4807880c763ddd5f0

#先还原二叉链表(其实有不用还原的更厉害的方法,见本人博客)
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
# 求二叉树的右视图
# @param xianxu int整型一维数组 先序遍历
# @param zhongxu int整型一维数组 中序遍历
# @return int整型一维数组
#它娘的终于弄明白它自动给的这行代码是干什么用的了,费老大劲儿
#就是提示你先序和中序的两个遍历列表已经给出,可以直接用,只等你return结果列表了
class Solution:
    def solve(self , xianxu: List[int], zhongxu: List[int]) -> List[int]:
        # write code here
        class binTreeNode: #定义结点
            def __init__(self):
                self.data='#'
                self.left=None
                self.right=None
        def createOrder(xianxu, zhongxu): #先还原二叉链表
            if zhongxu == []: #这两句可以换成if not zhongxu:return
                return None
            else:
                root = binTreeNode()
                root.data = xianxu[0]
                ind = zhongxu.index(root.data)
                root.left = createOrder(xianxu[1:], zhongxu[0:ind])
                root.right = createOrder(xianxu[ind + 1:], zhongxu[ind + 1:])
                return root
        def rightView(root,level): #生成右视图列表,一层一层进,同一层的后面的覆盖前面的
            if root==None:
                return
            elif level>len(res):
                res.append(root.data)
            elif level<=len(res):
                res[level-1]=(root.data) #每一层只能提取保留一个元素,新提取的覆盖旧的,层数是从1开始的,所以元素下标要层数减1
            rightView(root.left,level+1) #分别遍历左右子树
            rightView(root.right, level+1)
        root = createOrder(xianxu, zhongxu) #调用各函数
        level=1;global res;res=[] #列表、字典、集合之类的数据类型可以如此使用global即在外面声明一下即可,字符串、数字、元组等数据类型不可这样用,须在子函数内部用global声明
        rightView(root,level)
        return(res) #若不采用全局变量则res始终为空
全部评论

相关推荐

2025-12-16 22:45
已编辑
电子科技大学 活动运营
Rain_Codin...:简历感觉有点乱了而且一股AI味,AI简历的一个特点就是废话很多,一个点能分成四个点来讲,可以仔细优化一下。 btw,手机看简历不好看出来,可以把电脑上的简历截图放出来。
点赞 评论 收藏
分享
2025-12-28 20:47
已编辑
北京工商大学 Java
程序员牛肉:我靠你这个实习经历其实最需要担心的点是你做的太多了,可能会被面试官怀疑是你伪造的。 交易状态机是你做的,支付多渠道是你做的,对账是你做的,结算还是你做的,重复支付也是你做的,整个服务的异常处理也是你做的。 其实你这个反而问题很大的,你想想站在面试官的角度,他是真的会相信你的能力很强,还是相信这份实习你伪造了大部分?我相信你真的做了这么多,但是删一些,废话删一删。你这个做的太多了反而真实性不可信。 后面再补一个项目,在github上找一个高star的项目学一学然后写到自己简历上。我觉得你能力肯定没问题。28届能做到这个份上很厉害,但是在求职市场中,你不是在跟28届的同学比,把你这个简历放到27届其实也就一般水平。 所以后续要想一想看看能不能给自己简历上搞点亮点,比如开源贡献呢?比如博客呢?
实习要如何选择和准备?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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