跳转至

25.合并两个有序的链表 (Easy)*

题目描述*

输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增排序的。

示例*

输入:1->2->4, 1->3->4

输出:1->1->2->3->4->4

限制*

0 <= 链表长度 <= 1000

代码*

递归或迭代。

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
        ListNode *newHead = new ListNode(-1);
        ListNode *cur = newHead;
        while(l1 != nullptr && l2 != nullptr) {
            if(l1->val <= l2->val) {
                cur->next = l1;
                l1 = l1->next;
            }else {
                cur->next = l2;
                l2 = l2->next;
            }
            cur = cur->next;
        }
        if(l1 != nullptr) {
            cur->next = l1;
        }else if(l2 != nullptr) {
            cur->next = l2;
        }
        return newHead->next;
    }
};
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* l1, ListNode* l2) {
        if(l1 == nullptr) {
            return l2;
        }
        if(l2 == nullptr) {
            return l1;
        }
        if(l1->val <= l2->val) {
            l1->next = mergeTwoLists(l1->next, l2);
            return l1;
        }else {
            l2->next = mergeTwoLists(l1, l2->next);
            return l2;
        }
    }
};

最后更新: July 23, 2022