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;
    }
}
相关推荐
Lsk_Smion11 小时前
力扣实训 _ [75].颜色分类 _ 杨辉三角
数据结构·算法·leetcode
jidaowansui11 小时前
P11375 [GESP202412 六级] 树上游走
数据结构·算法
一切皆是因缘际会14 小时前
AI智能新时代
数据结构·人工智能·ai·架构
计算机安禾16 小时前
【数据库系统原理】第4篇:关系数据结构的形式化定义:域、笛卡尔积与关系模式
数据结构·数据库·算法
指针战神17 小时前
synchronized简易版Redis版跳表实现(注释干货)
数据结构
handler0118 小时前
【算法】并查集(普通/扩展/带权)模板与例题
数据结构·c++·笔记·算法·c·图论·查并集
糖果店的幽灵20 小时前
Pandas DataFrame 数据结构详解
数据结构·pandas
起个破名想半天了1 天前
算法与数据结构之Dijkstra算法
数据结构·dijkstra·单源最短路径·迪杰斯特拉算法
啦啦啦啦啦zzzz1 天前
数据结构:哈夫曼编码
数据结构·c++·哈夫曼编码
ChillCoding1 天前
更新中:C++ STL库,查找排序(基础算法),数据结构,数学算法,竞赛相关基础
数据结构·c++·算法