LeetCode21.合并两个有序链表

题目

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

LeetCode21.合并两个有序链表_第1张图片

示例 :
输入:l1 = [1,2,4], l2 = [1,3,4]
输出:[1,1,2,3,4,4]

思路

  • 创建一个新的链表头节点(dummyNode)和一个指针current,用于表示当前节点。

  • 在一个while循环中,比较两个链表的节点值,并依次将较小值的节点连接到新链表上。具体的步骤如下:

    • 如果list1的节点值小于等于list2的节点值,那么将current的next指针指向list1,并将list1指针后移一位。
    • 否则,将current的next指针指向list2,并将list2指针后移一位。
    • 然后,将current指针后移一位。
  • 当循环结束时,说明至少有一个链表已经遍历完毕。我们需要将剩余未遍历完的链表连接到新链表的末尾。具体的步骤如下:

    • 如果list1还有剩余节点,将current的next指针指向list1。
    • 如果list2还有剩余节点,将current的next指针指向list2。
  • 最后,返回dummyNode的next指针,即为合并后的新链表的头节点。

通过以上步骤,我们可以将两个升序链表合并为一个新的升序链表。该算法的时间复杂度为O(m+n),其中m和n分别为两个链表的长度。

Code:

class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        // 创建一个新的链表头节点
        ListNode dummyNode(0);
        ListNode* current = &dummyNode;

        // 比较两个链表的节点值,依次将较小值的节点连接到新链表上
        while (list1 && list2) {
            if (list1->val <= list2->val) {
                current->next = list1;
                list1 = list1->next;
            } else {
                current->next = list2;
                list2 = list2->next;
            }
            current = current->next;
        }

        // 将剩余未遍历完的链表连接到新链表上
        if (list1) {
            current->next = list1;
        }
        if (list2) {
            current->next = list2;
        }

        return dummyNode.next; // 返回新链表的头节点
    }
};

你可能感兴趣的:(链表,数据结构,c++,算法)