当前位置:网站首页>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)
边栏推荐
- Based on OpenGL glaciers and firebird (illumination calculation model, visual, particle system)
- [安洵杯 2019]easy_web
- Compose主题切换——让你的APP也能一键换肤
- 清除浮动与BFC
- 基于OpenGL的冰川与火鸟(光照计算模型、视景体、粒子系统)
- 动态生成不同类型的订单,请问如何存放到Mongodb数据库?
- golang刷leetcode动态规划(12)最小路径和
- Detailed explanation of common examples of dynamic programming
- golang刷leetcode 数学(1) 丑数系列
- 溜不溜是个问题
猜你喜欢

NC | Structure and function of soil microbiome reveal N2O release from global wetlands

Mysql安装流程 【压缩版】

MySQL安装(详细,适合小白)

【Psychology · Characters】Issue 1

Metaverse 001 | Can't control your emotions?The Metaverse is here to help you

脑机接口003 | 马斯克称已实现与云端的虚拟自己对话,相关概念股份大涨

openlayers版本更新差别

JVM内存和垃圾回收-04.程序计数器(PC寄存器)

EasyCVR平台通过国标GB28181接入柯达NVR显示注册失败,该如何解决?

LeetCode - 105. 从前序与中序遍历序列构造二叉树;023.合并K个升序链表
随机推荐
Geoserver+mysql+openlayers2
golang刷leetcode 动态规划(13) 最长公共子序列
leetcode刷题记录:7.整数反转,8.字符串转整数,9.回文数
动态规划常见实例详解
Therapy | How to Identify and Deal with Negative Thoughts
腾讯云孟凡杰:我所经历的云原生降本增效最佳实践案例
JVM内存和垃圾回收-04.程序计数器(PC寄存器)
光源控制器接口定义说明
PG 之 SQL执行计划
[安洵杯 2019]easy_web
Metaverse 001 | Can't control your emotions?The Metaverse is here to help you
【LeetCode】1374. 生成每种字符都是奇数个的字符串
Dynamically generate different types of orders, how do I deposit to mongo database?
EMQX Newsletter 2022-07|EMQX 5.0 正式发布、EMQX Cloud 新增 2 个数据库集成
2022-07-27
汇编实例解析--利用tcb,tss,全局tss,ldt管理任务实现任务切换
MaxCompute 近期发布上线的版本的 SQL 引擎新功能参数化视图有什么优势?
【C语言刷题】Leetcode203——移除链表元素
openlayers version update difference
Caldera(一)配置完成的虚拟机镜像及admin身份简单使用