题目描述
给你一个二叉树的根节点 root。设根节点位于二叉树的第 1 层,而根节点的子节点位于第 2 层,依此类推。请返回层内元素之和 最大 的那几层(可能只有一层)的层号,并返回其中 最小 的那个。
解析
在上一题(199)的基础上稍微修改代码即可。
public int maxLevelSum(TreeNode root) {
Queue<TreeNode> queue = new LinkedList<>();
queue.offer(root);
int max = Integer.MIN_VALUE;
int curHierarchy = 1;
int res = 0;
while (!queue.isEmpty()) {
int levelLength = queue.size();
int curSum = 0;
for (int i = 0; i < levelLength; i++) {
TreeNode node = queue.poll();
curSum += node.val;
if (node.left != null) {
queue.offer(node.left);
}
if (node.right != null) {
queue.offer(node.right);
}
}
if(curSum > max){
max = curSum;
res = curHierarchy;
}
curHierarchy ++;
}
return res;
}
深度优先遍历的方式也差不多,会稍微快点。
private List<Integer> sum = new ArrayList<Integer>();
public int maxLevelSum(TreeNode root) {
dfs(root, 0);
int ans = 0;
for (int i = 0; i < sum.size(); ++i) {
if (sum.get(i) > sum.get(ans)) {
ans = i;
}
}
return ans + 1; // 层号从 1 开始
}
private void dfs(TreeNode node, int level) {
if (level == sum.size()) {
sum.add(node.val);
} else {
sum.set(level, sum.get(level) + node.val);
}
if (node.left != null) {
dfs(node.left, level + 1);
}
if (node.right != null) {
dfs(node.right, level + 1);
}
}