力扣(LeetCode)23. 合并K个升序链表(C++)

news2024/12/25 14:38:33

模拟k路归并

朴素思想,类比二路归并, k k k 路归并多了一些参与比较的链表。我们可以在循环体内多一层循环,找到值最小的结点,插入答案链表的尾部。

朴素算法的时间复杂度 O ( k × ∑ i = 0 k − 1 l i s t s i . s i z e ( ) ) O(k\times\sum_{i=0}^{k-1} lists_i.size()) O(k×i=0k1listsi.size()) k k k 是链表个数 , l i s t i . s i z e ( ) list_i.size() listi.size() 是第 i i i 个链表的长度。至少遍历每个结点一次,时间复杂度 O ( ∑ i = 0 k − 1 l i s t s i . s i z e ( ) ) O(\sum_{i=0}^{k-1} lists_i.size()) O(i=0k1listsi.size()) 这是必须的。 找链表最小值 O ( k ) O(k) O(k) , 这一步可以用堆优化。

堆优化

建立小根堆,按链表值排序。将所有待比较结点加入堆,那么堆顶就是最小值 。

提示 : 优先队列默认大根堆 。 传入自定义的结构体,重载 “()” , 按链表值 , 建立小根堆 。 模板请背过。

class Solution {
public:
    typedef struct Cmp{
        bool operator () (ListNode* a,ListNode *b){
            return a->val>b->val;//按链表值,建立小根堆
        }
    }Cmp;
    ListNode* mergeKLists(vector<ListNode*>& lists) {
        priority_queue<ListNode *,vector<ListNode*>, Cmp> heap;
        for(auto &l:lists) if(l) heap.push(l);
        auto dummy = new ListNode(-1);
        auto tail = dummy;
        while(heap.size()){
            auto l = heap.top();
            heap.pop();
            if(l->next) heap.push(l->next);
            tail->next = l;
            tail = tail->next;
        }
        return dummy->next;
    }
};

时间复杂度 O ( l o g k × ∑ i = 0 k − 1 l i s t s i . s i z e ( ) ) O(logk\times\sum_{i=0}^{k-1} lists_i.size()) O(logk×i=0k1listsi.size())
用堆优化了查找最小值的时间复杂度 O ( l o g k ) O(logk) O(logk) , 至少遍历每个结点一次,时间复杂度 O ( ∑ i = 0 k − 1 l i s t s i . s i z e ( ) ) O(\sum_{i=0}^{k-1} lists_i.size()) O(i=0k1listsi.size()) , 总时间复杂度 O ( l o g k × ∑ i = 0 k − 1 l i s t s i . s i z e ( ) ) O(logk\times\sum_{i=0}^{k-1} lists_i.size()) O(logk×i=0k1listsi.size())

空间复杂度 O ( k ) O(k) O(k) , 堆中最多 k k k 个结点 , 空间复杂度 O ( k ) O(k) O(k)

博主致语

理解思路很重要!
欢迎读者在评论区留言,作为日更博主,看到就会回复的。

AC

AC

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/21037.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

做公众号1年啦

大家好&#xff0c;我是洋子 这里是北京的宇宙中心&#xff0c;西二旗地铁站&#xff0c;川流不息的人群&#xff0c;不断前进的脚步声&#xff0c;好像在告诉我们&#xff0c;新的一天工作即将开始 在地铁上&#xff0c;有人拿着手机刷着短视频&#xff0c;似乎还不想面对今…

第三十四篇 生命周期 - 易理解

通过之前一系列内容的推进来到生命周期的内容了&#xff0c;那么对于生命周期图示这块内容原文档内容有这么一段话&#xff1a;You don’t need to fully understand everything going on right now, but as you learn and build more, it will be a useful reference.&#xf…

jenkins构建gitee项目

流程是代码提交到gitee&#xff0c;jenkins中点击构建&#xff0c;自动删除目标服务器之前运行的jar包、拉取代码、构建、将jar包传到目标服务器、运行jar包。 1.下载jenkins运行 java -jar jenkins.war --httpPort8084 然后根据初始密码&#xff0c;创建账号&#xff0c;下载…

同花顺_代码解析_技术指标_P、Q

本文通过对同花顺中现成代码进行解析&#xff0c;用以了解同花顺相关策略设计的思想 目录 PBX PRICEOSC PSY PSYFS PVT QACD QLCX QLDX PBX 瀑布线 PBX1:(收盘价的M1日移动平均收盘价的M1*2日简单移动平均收盘价的M1*4日简单移动平均)/3 PBX2:(收盘价的M2日移动平均收…

320力扣周赛总结

目录 一、三元组数目 二、二叉树最近结点查询 三、到达首都的最少油耗 四、完美分割的方案数 一、三元组数目 6241. 数组中不等三元组的数目https://leetcode.cn/problems/number-of-unequal-triplets-in-array/ 思路&#xff1a;数据范围都非常小&#xff0c;三重循环即可…

Linux下的的GDB调试技巧一 —— 基础知识和介绍

基础知识 BUG BUG是一个英文单词&#xff0c;本意是指昆虫、小虫、损坏、犯贫、缺陷、窃听器等意思。在本文中是计算机领域专业术语&#xff0c;一般是指在电脑系统或程序中&#xff0c;隐藏着的一些未被发现的缺陷或问题&#xff0c;简称程序漏洞。另外bug还有一种引申意义&a…

MySQL表的增删改查操作(CRUD)

1. 新增1.1 插入一行全列插入1.2 插入多行指定列插入2. 查询2.1 全列查询2.2 指定列查询2.3 查询字段为表达式2.4 起个别名 as2.5 去重 distinct2.6 排序 order by2.7 条件查询 where2.8 分页查询 limit3. 修改 update4. 删除 delete增删查改(CRUD)即:增加(Create)、查询(Retri…

STC51单片机34——五线四相步进电机驱动(1个步进电机)

/*-------------------------------------------------------------------------------- MCU: STC15W408AS 注意其没有T1&#xff0c;但是有T2 开发板: STC15W408AS最小系统板 晶振: 内部时钟11.0592M&#xff0c;波特率3…

JavaScript面向对象:面向过程与面向对象

面向对象编程介绍 两大编程思想 面向过程 面向对象 面向过程编程 POP(Process-oriented programming) 面向过程就是分析出解决问题所需要的步骤&#xff0c;然后用函数把这些步骤一步一步实现&#xff0c;使用的时候再一个一个的依次调用就可以了。 举个栗子&#xff1a;…

STM32 CRC计算单元(循环冗余校验)

STM32第三篇【1】STM32 CRC计算单元【2】STM32 CRC简介【3】STM32 CRC主要特性【4】STM32 CRC功能描述【5】STM32 CRC寄存器【6】STM32 数据寄存器&#xff08;CRC_DR&#xff09;【7】STM32 独立数据寄存器&#xff08;CRC_IDR&#xff09;【8】STM32 控制寄存器&#xff08;C…

数字化转型模块设计

基于了解到现状及问题&#xff0c;设计部门提出如下的业务需求&#xff1a; 创建三维通用模型仓库&#xff1a; 在Windchill创建相应的存储库及文件夹&#xff0c;分别存储不同类型的通用模型&#xff0c;例如标准件、通用件、外购件等等&#xff1b;对于存储库及文件夹针对所…

k8s 资源管理

文章目录1. 资源管理介绍2. 资源管理方式2.1 命令式对象管理Kubectl 命令资源对象类型子命令输出格式namespace / pod的创建和删除演示2.2 命令式对象配置2.3 声明式对象配置3. kubectl 可以在 node 节点上运行吗&#xff1f;4. 使用推荐&#xff1a;三种方式应该怎么用&#x…

【王道计算机网络笔记】计算机网络体系结构-计算机网络体系结构与参考模型

文章目录计算机网络分层结构OSI参考模型TCP/IP参考模型5层参考模型5层参考模型的数据封装与解封装计算机网络分层结构 我们把计算机网络的各层及其协议的集合称为网络的体系结构(Architecture)。换言之&#xff0c;计算机网络的体系结构就是这个计算机网络及其所应完成的功能的…

Hash表实现原理

Hash表查找的本质就是&#xff1a;在创建记录表的时候&#xff0c;确定记录的key与其存储地址之间的关系f&#xff0c;当要查找keyk的记录时&#xff0c;通过关系 f 就可得到相应记录的地址而获取记录&#xff0c;从而免去了key的比较过程 我们把这个关系 f 称为Hash 函数&…

1.3 字符编码

文章目录1. 编码2. ASCII 字符集3. 字符编码发展4. Unicode 字符集5. 字符编码5.1 UTF-165.3 UTF-325.3 UTF-86. 文件编码转换7. 乱码问题1. 编码 计算机只能识别高低电平, 将高低电平用数字表示: 0表示低电压, 1表示高电平. 于是就创造出来二进制数, 一个二进制有 0 和 1, 两…

【网络工程】5、路由器介绍及配置实操

接上篇《4、企业级交换机配置》 之前我们通过eNSP完成了一个企业级交换机的配置实例&#xff0c;本篇我们继续来讲解网络设备——路由器的介绍&#xff0c;以及完成路由器的相关配置实操。 当我们申请了一条宽带后&#xff0c;一般都需要一台路由器来进行上网&#xff0c;那么…

SpringBoot项目创建及其核心设计思想

参考了很多相关博客: springboot怎么学&#xff1f; - 知乎 如何解读springboot 中约定大于配置、JPA是什么、咋用_打豆豆。的博客-CSDN博客 SpringBoot约定大于配置到底是什么意思&#xff1f;_zhupanlinch的博客-CSDN博客 SpringBoot约定大于配置的特性解读 & SpringBoot…

胶囊网络深入理解

胶囊网络的概念与理解 胶囊网络概述 人工神经元不应当追求神经元活动中的视角不变性&#xff0c;&#xff08;使用单一的标量输出来总结一个局部池中的重要特征的检测器的活动&#xff09;。而应当使用局部的胶囊&#xff0c;这些胶囊对其输入执行一些相当复杂的内部计算。然…

【Java】Java中时间的相关类(Date,SimpleDateFormat)

文章目录Date类SimpleDateFormat类Date类 Date是JDK提供的类&#xff0c;用来描述时间&#xff0c;使用无参构造创建的对象默认表示系统的当前时间&#xff0c;使用有参构造&#xff08;指定的毫秒值&#xff09;表示从时间原点&#xff08;1970年&#xff09;过了该参数值的时…

08_原始套接字

知识点1【原始套接字概述】 1、UDP封包格式 ​IP封包格式&#xff1a; Ethernet封包格式 TCP封包格式&#xff1a; ICMP封包格式&#xff1a;ping 知识点2【数据包的分析】 案例&#xff1a;网络分析器&#xff1a; 知识点2【混杂模式】接受数据&#xff08;了解&#x…