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

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

相关推荐
爱喝热水的呀哈喽1 分钟前
chns方程 推导简单的能量耗散律,分部积分向量形式,sav初简介
算法
代码游侠4 分钟前
应用——统计文件字符数、单词数、行数
服务器·笔记·算法
小裕哥略帅8 分钟前
Springboot中全局myBaits插件配置
java·spring boot·后端
岁岁的O泡奶9 分钟前
NSSCTF_crypto_[MTCTF 2021 final]ezRSA
经验分享·python·算法·密码学·crypto
别动哪条鱼12 分钟前
FFmpeg AVFormatContext 分配函数详解
数据结构·ffmpeg·音视频
MX_935916 分钟前
Spring中Bean注入方式和注入类型
java·后端·spring
沐雪架构师18 分钟前
AI大模型Agent面试精选15题(第二辑)
人工智能·面试·职场和发展
爱跑步的程序员~22 分钟前
IOC和AOP详解
java·spring
武哥聊编程24 分钟前
基于Springboot3+Vue3的仓库管理系统,经典项目,免费学习
java·学习·mysql·vue·springboot·课程设计
CoderYanger29 分钟前
C.滑动窗口-求子数组个数-越短越合法——LCP 68. 美观的花束
java·开发语言·数据结构·算法·leetcode