力扣热门100题之合并两个有序链表

思路:

用一个虚拟头节点 接住结果,然后像拉链一样,谁小就先拿谁

建一个虚拟头 dummy,用 cur 往后拼接

  1. 同时遍历 list1、list2

  2. 谁小就把谁接到 cur 后面,然后那条链表指针后移

  3. 最后把剩下不为空的整条直接接上

  4. 返回 dummy.next

合并链表的 "神器":虚拟头节点 后面跟一个移动指针 专门用来往后拼接新节点

完整代码实现:

java 复制代码
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        // 分别遍历两条链表 每次取较小的值加入新链表中 返回新链表
        //定义一个结果链表的头节点
        ListNode dummy = new ListNode(-1);
        ListNode curr = dummy;  //移动指针用来拼后面结点的

        while(list1 != null && list2 != null){
            if(list1.val<=list2.val){
                curr.next = list1;
                list1 = list1.next;
            }else{
                curr.next = list2;
                list2 = list2.next;
            }
            curr = curr.next;
        }

        // 剩下的直接拼上去
        if (list1 != null) {
            curr.next = list1;
        }
        if (list2 != null) {
            curr.next = list2;
        }
        return dummy.next;
    }
}
相关推荐
君义_noip18 小时前
CSP-S 2025 入门级 第一轮(初赛) 完善程序(1)
c++·算法·信息学奥赛·初赛·csp 第一轮
洛水水18 小时前
【力扣100题】41.爬楼梯
算法·leetcode·职场和发展
Pkmer18 小时前
LeetCode 上极少见的工程级滑窗实现
python·leetcode
sheeta199819 小时前
LeetCode 每日一题笔记 日期:2026.05.13 题目:1674. 使数组互补的最少操作次数
笔记·算法·leetcode
liulilittle19 小时前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信
每天回答3个问题19 小时前
LeetCodeHot100|回溯算法、46.全排列、78.子集、17.电话号码的字母组合
算法·深度优先·回溯
YL2004042619 小时前
038翻转二叉树
数据结构·leetcode
Liangwei Lin20 小时前
LeetCode 287. 寻找重复数
算法·leetcode·职场和发展
OCR_1337162127521 小时前
护照OCR校验位技术解析:从算法逻辑到工程落地,筑牢证件核验安全线
人工智能·算法
Hello.Reader21 小时前
算法基础(十三)——随机算法为什么有时主动引入随机性
java·数据库·算法