力扣热门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;
    }
}
相关推荐
To_OC3 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635078 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC9 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥10 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者11 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者12 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月14 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星15 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星15 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试