027合并两个有序链表

合并两个有序链表

题目链接:https://leetcode.cn/problems/merge-two-sorted-lists/description/?envType=study-plan-v2\&envId=top-100-liked

我的解答:

复制代码
public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
    if(list1==null){
        return list2;
    }
    if(list2==null){
        return list1;
    }
    ListNode head, cur;
    if(list1.val<=list2.val){
        head=list1;
        list1=list1.next;
    }
    else{
        head=list2;
        list2=list2.next;
    }
    cur=head;
    while(list1!=null&&list2!=null){
        if(list1.val<=list2.val){
            cur.next=list1;
            list1=list1.next;
        }
        else{
            cur.next=list2;
            list2=list2.next;
        }
        cur=cur.next;
    }
    if(list1==null){
        cur.next=list2;
    }
    else{
        cur.next=list1;
    }
    return head;
}

分析:代码的时间复杂度为O(n),空间复杂度为O(1)。解题思路:比较两个链表当前节点,谁当前节点的值小就让新链表的末尾节点连接谁,然后新链表和节点值更小的链表均向后移动一步,重复此过程,直到两个链表任意一个遍历到null,最后将另一个未遍历到空的链表剩余节点连接到新链表的末尾即可。

看了官方题解后的解答:

复制代码
//方法一:递归
//时间复杂度:O(n+m)
//空间复杂度:O(n+m)
public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
    if(list1==null){
        return list2;
    }
    if(list2==null){
        return list1;
    }
    if(list1.val<list2.val){
        list1.next = mergeTwoLists(list1.next,list2);
        return list1;
    }
    else{
        list2.next = mergeTwoLists(list1,list2.next);
        return list2;
    }
}

//方法二:迭代
//时间复杂度:O(n+m)
//空间复杂度:O(1)
public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
    ListNode prehead = new ListNode(-1);
    ListNode prev = prehead;
    while(list1!=null&&list2!=null){
        if(list1.val<=list2.val){
            prev.next=list1;
            list1=list1.next;
        }
        else{
            prev.next=list2;
            list2=list2.next;
        }
        prev=prev.next;
    }
    prev.next = list1==null ? list2 : list1;
    return prehead.next;
}

分析:

​ 1、方法一采用递归,每次递归返回当前两个节点中值更小的那个节点,直到某一个链表遍历到null为止。

​ 2、方法二采用迭代,先new一个哨兵节点,方便最后答案的返回,每次比较两个链表的头节点,将值更小的那个头节点连接到新节点末尾,直到某个节点遍历到null位置,最后将未遍历到null的节点连接到新节点之后返回即可。

​ 3、我的解题思路与官方题解的方法二一致,只不过我没有哨兵节点,而是在一开始单独比较两个链表头节点值的大小,确定出新链表的头节点。

总结

  • 本题较为简单,只需要不断比较两个链表头节点值的大小,并将值更小的节点连接到新链表的末尾即可。
相关推荐
JieE21215 小时前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
nanxun88619 小时前
记一次诡异的 Docker 容器"串包"故障排查
java
用户1563068103511 天前
Day01 | Java 基础(Java SE)
java
行者全栈架构师1 天前
Maven dependency:tree 的 8 个高级用法
java·后端
行者全栈架构师1 天前
IDEA 中 Maven 项目的 15 个红色报错快速解决方法
java·后端
令人头秃的代码0_01 天前
mac(m5)平台编译openjdk
java
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树2 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
唐青枫2 天前
Java JDBC 实战指南:从 Connection 到事务和连接池
java