LeetCode:21. 合并两个有序链表

简介

题目链接:https://leetcode.cn/problems/merge-two-sorted-lists/description/

解决方式:链表 + 双指针/递归

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

推荐查看腐烂的橘子、Krahets大佬所作题解。

双指针

解题思路:双指针。list1、list2就相当于两个指针,分别指向链表的第一个元素。此题不在原本的两个链表中进行修改,而是直接创建第三个链表。双指针指向的元素哪个小就先加入第三个链表。值得注意的是,第三个链表的头节点不能动,否则就会丢失节点,所以才有了 pre 指针往后移动。

java 复制代码
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        // 初始化第三方链表。链表头不能动,移动 pre 连接后面的节点
        ListNode list3 = new ListNode(0), pre = list3;
        // 迭代,当双方都不为 null 时
        while(list1 != null && list2 != null){
            if(list1.val >= list2.val){
                // 链表1的元素比链表2的大或相等,将链表2的元素移动到链表3
                pre.next = list2;
                list2 = list2.next;
            }else{
                // 反之,将链表1的元素移动到链表3
                pre.next = list1;
                list1 = list1.next;
            }
            // 移动到最后一个元素
            pre = pre.next;
        }
        // 有一个链表元素已经迭代完,则将剩下的另一个链表的元素全部移动到链表3
        pre.next = list1 != null ? list1 : list2;
        // 返回数据。伪头节点的下一个节点,真正的头节点。
        return list3.next;
    }
}

递归

解题思路:不断的比较双指针元素,在递到过程中找到较小的那个元素,在归的过程中将较小的元素指向下一个较小的元素,如此实现合并链表。 具体可以参考腐烂的橘子大佬的图形化过程。

java 复制代码
class Solution {
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
        // 递归终止条件
        if(list1 == null){
            return list2;
        }
        if(list2 == null){
            return list1;
        }
        // 递归公式
        // 找到双指针中较小的元素,该元素指向后面递归中较小的元素(但是大于等于该元素)
        if(list1.val >= list2.val){
            list2.next = mergeTwoLists(list1, list2.next);
            return list2;
        }else{
            list1.next = mergeTwoLists(list1.next, list2);
            return list1;
        }
    }
}
相关推荐
float_com3 分钟前
LeetCode 27. 移除元素
leetcode
王老师青少年编程6 分钟前
csp信奥赛c++中的递归和递推研究
c++·算法·递归·递推·csp·信奥赛
Bczheng118 分钟前
五.serialize.h中的CDataStream类
算法·哈希算法
小O的算法实验室19 分钟前
2025年SEVC,考虑组件共享的装配混合流水车间批量流调度的多策略自适应差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
汀、人工智能22 分钟前
[特殊字符] 第36课:柱状图最大矩形
数据结构·算法·数据库架构·图论·bfs·柱状图最大矩形
List<String> error_P28 分钟前
蓝桥杯最后冲刺(三)
算法
样例过了就是过了39 分钟前
LeetCode热题100 跳跃游戏
c++·算法·leetcode·贪心算法·动态规划
无限进步_43 分钟前
【C++&string】寻找字符串中第一个唯一字符:两种经典解法详解
开发语言·c++·git·算法·github·哈希算法·visual studio
FluxMelodySun43 分钟前
机器学习(二十九) 稀疏表示与字典学习(LASSO算法、KSVD算法、奇异值分解)
人工智能·算法·机器学习
LG.YDX1 小时前
笔试训练48天:跳台阶
数据结构·算法