Grind 75 | 3. merge two sorted lists

Leetcode 21. 合并两个有序链表

题目链接

思路:

  • 和归并排序中 merge 部分一致
    1. 两个指针分别指向 2 个链表头
    2. 每次选小的那个加入 res 中,对应指针后移一位;
    3. 重复步骤2,直至一个指针到链表末尾
    4. 将另一个剩余的全部 copy 到 res 中,链表只需要修改末尾结点指向
  • 链表添加结点操作
cpp 复制代码
class Solution {
public:
    ListNode* mergeTwoLists(ListNode* list1, ListNode* list2) {
        ListNode* res = new ListNode();
        ListNode* p = res;
        while (list1 && list2) {
            int x = list1->val;
            int y = list2->val;
            if (x <= y) {
                p->next = list1;
                list1 = list1->next;
            }
            else {
                p->next = list2;
                list2 = list2->next;
            }
            p = p->next;
        }
        if (list1 && !list2) {
            p->next = list1;
        }
        if (list2 && !list1) {
            p->next = list2;
        }
        return res->next;
    }
};
相关推荐
Darkwanderor4 小时前
什么数据量适合用什么算法
c++·算法
zc.ovo5 小时前
河北师范大学2026校赛题解(A,E,I)
c++·算法
py有趣5 小时前
力扣热门100题之环形链表
算法·leetcode·链表
py有趣5 小时前
力扣热门100题之回文链表
算法·leetcode·链表
Kk.08025 小时前
数据结构|链表 刷题
数据结构·链表
月落归舟6 小时前
帮你从算法的角度来认识二叉树---(二)
算法·二叉树
清华都得不到的好学生7 小时前
数据结构->1.稀疏数组,2.数组队列(没有取模),3.环形队列
java·开发语言·数据结构
SilentSlot7 小时前
【数据结构】Hash
数据结构·算法·哈希算法
是娇娇公主~8 小时前
Lambda表达式详解
数据结构·c++