力扣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; // 返回真正头
    }
};
相关推荐
青山木1 天前
Hot 100 --- 轮转数组
java·数据结构·算法
WBluuue1 天前
数据结构与算法:有序表(二):跳表
数据结构·c++·算法·skiplist
不好听6132 天前
深入理解链表:线性数据结构的另一面
javascript·数据结构
Queenie_Charlie2 天前
哈夫曼树
数据结构·c++·哈夫曼树
Shan12052 天前
经典问题——验证栈序列
数据结构·算法
漂流瓶jz2 天前
UVA-1606 两亲性分子 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·向量·aoapc·算法竞赛入门经典·atan2·浮点
Chen_harmony2 天前
二、顺序表
数据结构
BAGAE2 天前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
h_a_o777oah2 天前
【算法专项】扩展域并查集:原理详解及解决大部分种类并查集问题(洛谷P5937 P2024 C++代码)
数据结构·c++·算法·acm·并查集·扩展域·逻辑建模
吴阿福|一人公司2 天前
深度解析 Python 类变量修改的命名空间隔离
java·服务器·数据结构