23. 合并 K 个升序链表

首先对于两个链表的升序组合我们是熟悉的,我们可以创建四个指针

head指针用来指向合并链表的头部,用来返回结果

tail指针用来指向合并链表的尾部,tail.next用来指向下一个要插入的节点

aPtr指针用来指向链表a的待插入部分第一个节点

bPtr指针用来指向链表b的待插入部分第一个节点

每个tail.next进行比较大小就行

k个链表使用for循环遍历每个链表,并且维护一个ans链表即可

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode mergeKLists(ListNode[] lists) {
        //答案链表
        ListNode ans = null;
        //循坏数组长度次,每一次把遍历到的LintNode合并进ans
        for (int i = 0; i < lists.length; i++) {
            ans = mergeTwoLists(ans, lists[i]);
        }
        return ans;
    }
    public ListNode mergeTwoLists(ListNode a, ListNode b) {
        if (a == null || b == null) {
            return a != null ? a : b;
        }
        //创建四个指针
        //head指针用来指向ans的开头,方便最后直接返回
        //tail指针用来指向下一个要插入的位置
        //aPtr用来指向a链表待插入的位置
        //bPtr用来指向b链表待插入的位置
        ListNode head = new ListNode(0);
        ListNode tail = head;
        ListNode aPtr = a;
        ListNode bPtr = b;
        while (aPtr != null && bPtr != null) {
            if (aPtr.val < bPtr.val) {
                tail.next = aPtr;
                aPtr = aPtr.next;
            }else{
                tail.next = bPtr;
                bPtr = bPtr.next;
            }
            tail = tail.next;
        }
        //循环结束,可能有一个链表遍历完了,直接接上另一个链表
        tail.next = (aPtr != null ? aPtr : bPtr);
        return head.next;
    }
}
相关推荐
Mr_pyx2 小时前
面试题记录
jvm·数据结构·算法·spring·mybatis
努力努力再努力wz2 小时前
【C++高阶数据结构系列】:时间轮定时器详解:原理分析与代码实现,带你从零手撕时间轮!(附时间轮的实现源码)
c语言·开发语言·数据结构·c++·qt·算法·ui
iiiiyu2 小时前
⾯向对象和集合编程题
java·大数据·开发语言·数据结构·编程语言
YuanDaima20482 小时前
贪心算法基础原理与题目说明
数据结构·人工智能·python·算法·贪心算法·手撕代码
人道领域2 小时前
【LeetCode刷题日记】513.二叉树左下角值的三种解法:从常规BFS到DFS的优雅之旅
数据结构·算法·leetcode·深度优先·广度优先
雁迟2 小时前
第七章:R 向量用法(最核心数据结构)
开发语言·数据结构·r语言
兰令水3 小时前
topcode【随机算法题】【2026.5.16打卡-java版本】
java·数据结构·算法
Shan12053 小时前
广度优先搜索之层序遍历
数据结构·算法·宽度优先
清辞8533 小时前
集合竞价选股程序开发学习
数据结构