力扣HOT100(27) 合并两个有序链表

迭代法:

两个链表都是升序的,所以每次只需要比较两个链表当前的头节点,把值更小的那个节点接在新链表的后面,然后把对应的链表指针往前走一步。重复这个过程,直到其中一个链表走完,最后把剩下的那个链表直接接在新链表的末尾即可。

想象有两个队伍,都是按身高从矮到高排好的

  • 队伍 1:1 号(1 米)→ 2 号(1.2 米)→ 4 号(1.4 米)
  • 队伍 2:1 号(1 米)→ 3 号(1.3 米)→ 4 号(1.4 米)

现在要把这两个队伍合并成一个新队伍,还是从矮到高排

**每次只看两个队伍的第一个人,把更矮的那个拉到新队伍里,然后这个队伍的下一个人变成第一个。**重复这个过程,直到其中一个队伍没人了,最后把剩下的那个队伍整个拉到新队伍后面就行。

代码中需要注意的是:要先创建一个虚拟的链表头,为了让链表有个头,然后还需要有个tail指针 始终指向链表的最后一个节点。开始指向的是这个虚拟的链表头。然后把节点存到新指针的时候呢,就是tail->的下个节点 等于 我们要存的即可。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        ListNode* p1 = list1;
        ListNode* p2 = list2;

        // ========= 你缺的 =========
        ListNode* dummy = new ListNode(-1); // 虚拟头。new ListNode创建新节点
        ListNode* tail = dummy;             // 尾巴指针,开始指向虚拟头

        while(p1!=nullptr && p2!= nullptr){

            if(p1->val <= p2->val ){  // 如果p1不大于p2
                // === 存 p1 ===
                tail->next = p1; //当前最后一节点的下一个存入我们的新节点
                p1 = p1->next;
            }
            else{
                // === 存 p2 ===
                tail->next = p2;
                p2 = p2->next;
            }
            tail = tail->next; // 尾巴必须走! 因为必须指向最后一个节点。
        }

        // === 把剩下的直接接上 ===
        if(p1 == nullptr){
            tail->next = p2;
        }
        else{
            tail->next = p1;
        }

        return dummy->next; // 返回真正头
    }
};
相关推荐
鱼子星_9 小时前
【数据结构与算法】数据结构基础——树(上):树的存储结构,满二叉树,完全二叉树,二叉树的存储结构
c语言·数据结构·算法
南境十里·墨染春水9 小时前
数据结构——栈
数据结构
iiiiyu9 小时前
面向对象案例
java·大数据·开发语言·数据结构·python·编程语言
奶人五毛拉人一块9 小时前
滑动窗口算法及习题讲解
数据结构·算法·滑动窗口·子数组
加油20199 小时前
嵌入式软件技术栈和学习路线详解
linux·arm开发·数据结构·mqtt·设计模式·嵌入式
是main不是漫10 小时前
【数据结构--双向链表】从前有个节点,它想要两头讨好…
c语言·数据结构·链表
南境十里·墨染春水10 小时前
数据结构——AVL二叉平衡树
数据结构
过期动态10 小时前
【RabbitMQ高级篇】生产者可靠性、MQ可靠性、消费者可靠性以及延迟队列的实现
java·数据结构·分布式·算法·rabbitmq·ruby
『昊纸』℃11 小时前
《C语言电子新-2026最新版》-编程语言与程序
数据结构·算法·程序设计·编程语言·软件开发