力扣热门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;
    }
}
相关推荐
8Qi82 小时前
LeetCode热题100--45.跳跃游戏 II
java·算法·leetcode·贪心算法·编程
foundbug9992 小时前
基于STM32的步进电机加减速程序设计(梯形加减速算法)
stm32·单片机·算法
北顾笙9802 小时前
day12-数据结构力扣
数据结构·算法·leetcode
凌波粒3 小时前
LeetCode--454.四数相加 II(哈希表)
算法·leetcode·散列表
漫随流水3 小时前
c++编程:D进制的A+B(1022-PAT乙级)
数据结构·c++·算法
tankeven3 小时前
HJ159 没挡住洪水
c++·算法
美式请加冰3 小时前
斐波那契数列介绍和使用
算法
paeamecium3 小时前
【PAT】 - Course List for Student (25)
数据结构·c++·算法·pat考试
wen__xvn4 小时前
力扣洛谷模拟题刷题2
算法·leetcode·职场和发展