当前位置:网站首页>Leetcode刷题——23. 合并K个升序链表
Leetcode刷题——23. 合并K个升序链表
2022-08-02 19:23:00 【lonelyMangoo】
21. 合并两个有序链表
先看看这题合并两个有序链表
思路:找出两个链表中较小的元素链接到结果链表,当有一个链表为空时,另一个直接连接到目标结尾即可。
public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
ListNode listNode = new ListNode();
ListNode res = listNode;
while (list1!=null && list2!=null){
int val1= list1.val;
int val2= list2.val;
if(val1<val2){
listNode.next=list1;
list1=list1.next;
}else{
listNode.next=list2;
list2=list2.next;
}
listNode=listNode.next;
}
if(list1!=null){
listNode.next=list1;
}
if(list2!=null){
listNode.next=list2;
}
return res.next;
}
23. 合并K个升序链表
再看这道题:
23. 合并K个升序链表
首先第一思路是就是两两合并。
代码如下:
public ListNode mergeKLists(ListNode[] lists) {
if(lists.length == 0){
return null;
}
if(lists.length==1){
return lists[0];
}
for (int i = 1; i < lists.length; i++) {
lists[i]=mergeTwoLists(lists[i],lists[i-1]);
}
return lists[lists.length-1];
}
这样实现起来虽然简单,但是时间效率很差,因为合并是O(n),每次都遍历和之前的合并,时间复杂度也是O(n),所以之间复杂度是O(n^2)
归并排序
其实很容易想到,里面有很多冗余的步骤,可以两两合并,也就是我们熟悉的归并排序。
在我们用数组排序的时候,创建一个新的数组,每次归并,都对指定指定位置的元素修改。
而这里链表则是每次都返回排序好的链表进行合并。
在归并的底层是单个元素,所以当left == right的时候,直接返回当前元素。
代码:
private static ListNode mergeLists(ListNode[] lists,int left ,int right) {
int mid = (left+right)/2;
if(left == right){
return lists[left];
}
if(left<right){
ListNode listNode1 = mergeLists(lists, left, mid);
ListNode listNode2 = mergeLists(lists, mid + 1, right);
return mergeTwoLists(listNode1,listNode2);
// mergeTwoLists(lists[left],l)
}
return null;
}
这样的话时间复杂度就变成了O(n*logn)
边栏推荐
- thinkphp框架5.0.23安全更新问题-漏洞修复-/thinkphp/library/think/App.php具体怎么改以及为什么要这么改
- PG 之 SQL执行计划
- Brain-computer interface 003 | Musk said that he has realized a virtual self-dialogue with the cloud, and related concept shares have risen sharply
- Golang sync/atomic 包的原子操作说明
- openlayers版本更新差别
- Fetch 请求不转换BLOB正常显示GBK编码的数据
- MySQL安装配置教程(超级详细)
- MySQL 事件调度
- 连续三次 | 灵雀云入选Gartner中国ICT技术成熟度曲线报告
- 2022-08-01
猜你喜欢

连续三次 | 灵雀云入选Gartner中国ICT技术成熟度曲线报告

MySQL 事件调度

动态折线图,制作原来是这么简单

解析Collection接口中的常用的被实现子类重写的方法

你想要的宏基因组-微生物组知识全在这(2022.8)

Mysql基础篇(视图)

thinkphp框架5.0.23安全更新问题-漏洞修复-/thinkphp/library/think/App.php具体怎么改以及为什么要这么改

SCANIA SCANIA OTL tag is introduced

什么是现场服务管理系统(FSM)?有什么好处?

Metaverse 001 | Can't control your emotions?The Metaverse is here to help you
随机推荐
el-tree渲染大量数据的解决方案(不通过懒加载)
4KMILES加入艾盛集团,以更强劲的数字商务能力,加速中国跨境电商的全域全效增长
Cannot find declaration to go to
NC | 土壤微生物组的结构和功能揭示全球湿地N2O释放
openlayers version update difference
Geoserver + mysql + openlayers problem
Based on OpenGL glaciers and firebird (illumination calculation model, visual, particle system)
LeetCode:622. 设计循环队列【模拟循环队列】
Kali命令ifconfig报错command not found
看完这篇,轻松get限流!
【C语言刷题】Leetcode238——除自身以外数组的乘积
TPAMI2022 | TransCL:基于Transformer的压缩学习,更灵活更强大
idea 配置resin
golang刷leetcode 经典(13) 最小高度树
spack install reports an error /tmp/ccBDQNaB.s: Assembler message:
解析List接口中的常用的被实现子类重写的方法
E. Add Modulo 10(规律)
Therapy | How to Identify and Deal with Negative Thoughts
磁盘分区的知识
MaxCompute 的SQL 引擎参数化视图具体有哪些增强功能?