概述
【题目】
给你一个二叉树的根节点 root。设根节点位于二叉树的第 1 层,而根节点的子节点位于第 2 层,依此类推。
请你找出层内元素之和 最大 的那几层(可能只有一层)的层号,并返回其中 最小 的那个。
示例 1:
输入:root = [1,7,0,7,-8,null,null]
输出:2
解释:
第 1 层各元素之和为 1,
第 2 层各元素之和为 7 + 0 = 7,
第 3 层各元素之和为 7 + -8 = -1,
所以我们返回第 2 层的层号,它的层内元素之和最大。
示例 2:
输入:root = [989,null,10250,98693,-89388,null,null,null,-32127]
输出:2
提示:
树中的节点数介于 1 和 10^4 之间
-10^5 <= node.val <= 10^5
【代码】
class Solution:
def dfs(self,root,dep):
if not root:
return
if dep>len(self.ans):
self.ans.append(root.val)
else:
self.ans[dep-1]+=root.val
self.dfs(root.left,dep+1)
self.dfs(root.right,dep+1)
def maxLevelSum(self, root: TreeNode) -> int:
self.ans=[]
self.dfs(root,1)
return self.ans.index(max(self.ans))+1
最后
以上就是火星上抽屉为你收集整理的【树-中等】1161. 最大层内元素和的全部内容,希望文章能够帮你解决【树-中等】1161. 最大层内元素和所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复