LeetCode 21.合并两个有序链表

Posted 龚喜发财+1

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 21.合并两个有序链表相关的知识,希望对你有一定的参考价值。

**题目:**将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。
在这里插入图片描述
题解1(迭代)创建一个新的链表,用cur为头部开始连接,选取两个链表中的较小元素放入新的链表中,最后如果还剩余某个链表,则将其剩下的全部内容连接到新的链表中。
创建一个哑结点来处理边界条件ListNode preHead=new ListNode(0);

public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        if(l1==null)
            return l2;
        if(l2==null)
            return l1;
        //创建一个哑结点,处理边界条件
        ListNode preHead=new ListNode(0);
        ListNode cur=preHead;
        while(l1!=null&&l2!=null){
            if(l1.val>l2.val){
                cur.next=l2;
                cur=l2;
                l2=l2.next;
            }
            else{
                cur.next=l1;
                cur=l1;
                l1=l1.next;
            }
        } 
        if(l1==null)
           cur.next=l2;
        if(l2==null)
            cur.next=l1;
        // 合并后 l1 和 l2 最多只有一个还未被合并完,我们直接将链表末尾指向未合并完的链表即可
        //cur.next = l1 == null ? l2 : l1;
        return preHead.next;
    }

时间复杂度O(m+n)mn为链表长度
空间复杂度O(1)
题解2(递归)至死不会递归!
终止条件:l1或l2为空时,跳出递归

class Solution {
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        if (l1 == null) {
            return l2;
        } else if (l2 == null) {
            return l1;
        } else if (l1.val < l2.val) {
            l1.next = mergeTwoLists(l1.next, l2);
            return l1;
        } else {
            l2.next = mergeTwoLists(l1, l2.next);
            return l2;
        }

    }
}

思路:在l1和l2中首先比较队头元素,选择较小的放在合并后的链表中,然后在其他剩下的链表元素中的队头进行比较找到最小的,也就是说我们要判断 l1 和 l2 哪一个链表的头节点的值更小,然后递归地决定下一个添加到结果里的节点。如果两个链表有一个为空,递归结束。
时间复杂度O(M+N)
空间复杂度O(M+N)

以上是关于LeetCode 21.合并两个有序链表的主要内容,如果未能解决你的问题,请参考以下文章

leetcode21合并两个有序链表

LeetCode 21. 合并两个有序链表

leetCode第21题——合并两个有序链表

LeetCode 21.合并两个有序链表

LeetCode 21.合并两个有序链表

[leetcode] 21. 合并两个有序链表