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);
}

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

相关推荐
程序员夏末2 分钟前
【LeetCode | 第四篇】算法笔记
笔记·算法·leetcode
小指纹3 分钟前
线性数据结构--栈
数据结构
Mr.朱鹏4 分钟前
分布式-redis集群架构
java·redis·分布式·后端·spring·缓存·架构
予枫的编程笔记5 分钟前
【面试专栏|Java并发编程】Java并发锁对比:synchronized与Lock,底层原理+适用场景详解
java·synchronized·java面试·java并发编程·并发锁·面试干货·lock接口
醇氧6 分钟前
PowerPoint 批量转换为 PDF
java·spring boot·spring·pdf·powerpoint
李昊哲小课6 分钟前
Python 数据结构示例
开发语言·数据结构·python
java1234_小锋7 分钟前
Java高频面试题:RabbitMQ如何实现消息的持久化?
java·开发语言
DeepModel12 分钟前
【概率分布】多项分布详解
算法·概率论
爱打代码的小林15 分钟前
用 LangChain 解析大模型输出
java·python·langchain·大模型
_日拱一卒17 分钟前
LeetCode(力扣):只出现一次的数字
java·数据结构·算法