LeetCode21.合并两个有序链表

题目

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

请添加图片描述

示例 :
输入: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; // 返回新链表的头节点
    }
};

相关推荐

  1. Leetcode21 合并有序

    2024-02-20 16:34:05       36 阅读
  2. Leetcode 21合并有序

    2024-02-20 16:34:05       31 阅读
  3. [leetcode] 21. 合并有序

    2024-02-20 16:34:05       15 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-20 16:34:05       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-20 16:34:05       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-20 16:34:05       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-20 16:34:05       18 阅读

热门阅读

  1. 关于安卓artifactory本地仓库搭建docker(二)

    2024-02-20 16:34:05       32 阅读
  2. 揭秘员工心声:如何高效进行员工满意度调查?

    2024-02-20 16:34:05       25 阅读
  3. c# 字符串解析乱码

    2024-02-20 16:34:05       29 阅读
  4. conda 所有的命令及其讲解

    2024-02-20 16:34:05       25 阅读
  5. nginx.conf之listen与server_name的意义

    2024-02-20 16:34:05       29 阅读
  6. 奇门遁甲 API接口

    2024-02-20 16:34:05       43 阅读
  7. Element UI组件的安装及使用

    2024-02-20 16:34:05       25 阅读
  8. kube-ovn自定义vpc

    2024-02-20 16:34:05       22 阅读
  9. 开源BLHELI-S 代码详细解读(四)

    2024-02-20 16:34:05       21 阅读
  10. Vue3中watch与watchEffect的区别

    2024-02-20 16:34:05       23 阅读