当前位置: 首页 > news >正文

LeetCode 23.合并K个升序链表

给你一个链表数组,每个链表都已经按升序排列。

请你将所有链表合并到一个升序链表中,返回合并后的链表。

示例 1:

输入:lists = [[1,4,5],[1,3,4],[2,6]]
输出:[1,1,2,3,4,4,5,6]
解释:链表数组如下:
[
1->4->5,
1->3->4,
2->6
]
将它们合并到一个有序链表中得到。
1->1->2->3->4->4->5->6
示例 2:

输入:lists = []
输出:[]
示例 3:

输入:lists = [[]]
输出:[]

提示:

k == lists.length
0 <= k <= 10^4
0 <= lists[i].length <= 500
-10^4 <= lists[i][j] <= 10^4
lists[i] 按 升序 排列
lists[i].length 的总和不超过 10^4

我们可以用小顶堆维护每个链表的头节点,然后每次取堆顶的节点加入结果链表:

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */classSolution{public:ListNode*mergeKLists(vector<ListNode*>&lists){vector<pair<int,int>>h;for(inti=0;i<lists.size();++i){if(lists[i]!=nullptr){h.push_back({lists[i]->val,i});}}make_heap(h.begin(),h.end(),greater());ListNode*ans=nullptr;ListNode*cur=nullptr;while(h.size()>0){intminIdx=h[0].second;if(ans==nullptr){ans=lists[minIdx];cur=ans;}else{cur->next=lists[minIdx];cur=cur->next;}pop_heap(h.begin(),h.end(),greater());h.pop_back();lists[minIdx]=lists[minIdx]->next;if(lists[minIdx]!=nullptr){h.push_back({lists[minIdx]->val,minIdx});push_heap(h.begin(),h.end(),greater());}}returnans;}};

如果所有链表中总共有n个节点,有个k个链表,则此算法时间复杂度为O(k+nlogk),空间复杂度为O(k)。

http://www.gsyq.cn/news/1618012.html

相关文章:

  • Visa、Stripe等140余家机构联合推出Open USD稳定币,剑指Tether
  • HBM Predictor安装与配置教程:简单5步搭建预测环境
  • 年入100亿压缩机龙头IPO!1.66亿诉讼案未决,应收账款质量恶化
  • ChatGPT Plus / Pro 付款后没看到结果,先查这几步
  • 番茄小说下载器终极指南:三分钟打造个人离线图书馆的完整教程
  • 单帧像素推演三维空间,SpaceOS联动Pixel2Geo打通单画面实景重建全链路
  • YOLOv11 改进 - C2PSA C2PSA融合EDFFN高效判别频域前馈网络(CVPR 2025):频域筛选机制增强细节感知,优化复杂场景目标检测
  • 软件设计周期
  • 孩子确诊自闭症/多动症后该找谁?一份给迷茫家长的专业参考指南
  • M4Markets的长期使用感受顺不顺手?
  • 卡梅德生物科普:CD70(TNFSF7)的免疫共刺激机制与研究应用
  • 功能极简取舍:每个按钮都要为用户承担重量
  • Kiran-shell 显示桌面插件:一键隐藏所有窗口的底层机制
  • CPP 学习笔记 语法总结
  • 第91题 2026年国家级科研痛点:高压IGBT芯片场截止(FS)结构与背面减薄工艺
  • 选芯片编程烧录座,这3个专业性价比最稳
  • 直流电机静音控制方案:从PWM优化到PCB布局
  • SQL 复杂查询优化:先减少扫描,再谈语法漂亮
  • 6. 深入 Nginx 核心:HTTP 11 个处理阶段与模块开发实战
  • 【2026年华为暑期实习(AI)-7月1日-第三题- Certainty Forcing 训练损失计算】(题目+思路+JavaC++Python解析+在线测试)
  • AI 辅助:前端工程化效率:快不是少检查,而是少返工
  • 深度学习Pipeline与Baseline构建指南
  • 截屏、OCR、翻译、录屏全打包?这款开源软件,一个快捷键搞定所有!
  • 工程化赋能传统业务工作流:先找重复劳动,不要先找服务
  • SpringBoot 自动配置原理
  • 死磕信号量实现读者-写者:我被自己写的代码坑惨了
  • Xinference开源大模型本地部署实战指南
  • UABEA:重新定义Unity资源编辑的跨平台革命
  • 大厂高频面试题:手机号加密存储后,如何快速按尾号查询?
  • 终极Windows驱动管理指南:DriverStoreExplorer免费释放C盘空间