2024.2.23力扣每日一题——二叉树中的第 K 大层和

2024.2.23

题目来源

力扣每日一题;题序:2583

我的题解

方法一 层序遍历+排序

先使用层序遍历计算每一层的和,然后将每一层的和进行排序。
时间复杂度 :O(nlogn)。其中 n 是树中的节点数。广度优先搜索消耗 O(n),一次排序消耗 O(n×log⁡n)。
空间复杂度:O(n)

java 复制代码
public long kthLargestLevelSum(TreeNode root, int k) {
    Queue<TreeNode> queue=new LinkedList<>();
    queue.offer(root);
    List<Long> sum=new ArrayList<>();
    while(!queue.isEmpty()){
        int sz=queue.size();
        long cur_sum=0;
        for(int i=0;i<sz;i++){
            TreeNode t=queue.poll();
            cur_sum+=t.val;
            if(t.left!=null){
                queue.offer(t.left);
            }
            if(t.right!=null)
                queue.offer(t.right);
        }
        sum.add(cur_sum);
    }
    if(sum.size()<k)
        return -1;
    sum.sort((a,b)->b.compareTo(a));
    return sum.get(k-1);
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
sunywz2 分钟前
【JVM】(2)java类加载机制
java·jvm·python
千金裘换酒3 分钟前
LeetCode 环形链表+升级版环形链表
算法·leetcode·链表
小鸡吃米…3 分钟前
机器学习中的随机森林算法
算法·随机森林·机器学习
进阶小白猿7 分钟前
Java技术八股学习Day13
java·jvm·学习
CodeAmaz14 分钟前
ConcurrentHashMap(JDK 7/8)详细介绍
java·hashmap·线程安全map
大猫和小黄15 分钟前
Tomcat vs Undertow 全面对比
java·tomcat
霁月中20 分钟前
[Codeforces Round 1065 (Div. 3)](A-D,F)
算法
世洋Blog23 分钟前
算法导论-分治法和合并(Merge)排序
算法
源代码•宸28 分钟前
Golang基础语法(go语言结构体、go语言数组与切片、go语言条件句、go语言循环)
开发语言·经验分享·后端·算法·golang·go
霍田煜熙33 分钟前
【无标题】
java