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;
    }
};
相关推荐
budingxiaomoli5 分钟前
优选算法-多源bfs解决拓扑排序问题
算法·宽度优先
隔壁大炮5 分钟前
10.PyTorch_元素类型转换
人工智能·pytorch·深度学习·算法
海清河晏1115 分钟前
数据结构 | 顺序栈
数据结构
The Chosen One9856 分钟前
算法题目分享(二分算法)
算法·职场和发展·蓝桥杯
疯狂打码的少年7 分钟前
数据结构图的存储方式:从邻接矩阵到十字链表,一文打尽
数据结构·链表
玛丽莲茼蒿8 分钟前
Leetcode hot100 矩阵置零【中等】
算法·leetcode·矩阵
Queenie_Charlie9 分钟前
关于二叉树(2)
数据结构·c++·二叉树·简单树结构
澈2079 分钟前
算法进阶:二叉树翻转与环形链表解析
数据结构·算法·排序算法
:1219 分钟前
java数组2
java·算法·排序算法
代码飞天10 分钟前
算法与数据结构之树——让数据查找更加迅速
数据结构·算法