题目讲解15 合并两个排序的链表

原题链接:

合并两个排序的链表_牛客题霸_牛客网

思路分析:

第一步:写一个链表尾插数据的方法。

复制代码
typedef struct ListNode ListNode;

//申请结点
ListNode* BuyNode(int x)
{
    ListNode* node = (ListNode*)malloc(sizeof(ListNode));
    node->val = x;
    node->next = NULL;
    return node;
}

//尾插
void ListPushBack(ListNode** pphead, int x)
{
    ListNode* NewNode = BuyNode(x);
    if(*pphead == NULL)
    {
        *pphead = NewNode;
    }
    else 
    {
        ListNode* pcur = *pphead;
        while(pcur->next)
        {
            pcur = pcur->next;
        }
        pcur->next = NewNode;
    }
}

第二步:创建三个链表结点。l1 用来遍历链表1,l2用来遍历链表2,RetList 是返回链表。

复制代码
ListNode* RetList = NULL, *l1 = pHead1, *l2 = pHead2;

第三步:进行遍历判断。如果 l1 结点里的值小于 l2 结点里的值,就把 l1 结点里的值尾插到返回链表。反之,就把 l2 结点里是值尾插到返回链表。

复制代码
    while(l1 && l2)
    {
        if(l1->val < l2->val)
        {
            ListPushBack(&RetList, l1->val);
            l1 = l1->next;
        }
        else
        {
            ListPushBack(&RetList, l2->val);
            l2 = l2->next;
        }
    }

循环之前:

第一次循环之后:

第二次循环之后:

第三次循环之后:

第四次循环之后:

第五次循环之后:

如果 l1 或者 l2 遍历到 NULL 的时候,会有一方没有完全遍历完所有结点,所以我们还需要补上两个循环去遍历完 l1 或者 l2。

复制代码
    while(l1)
    {
        ListPushBack(&RetList, l1->val);
        l1 = l1->next;
    }
    while(l2)
    {
        ListPushBack(&RetList, l2->val);
        l2 = l2->next;
    }
    return RetList;

完整代码:

复制代码
struct ListNode* Merge(struct ListNode* pHead1, struct ListNode* pHead2 ) 
{
    ListNode* RetList = NULL, *l1 = pHead1, *l2 = pHead2;
    while(l1 && l2)
    {
        if(l1->val < l2->val)
        {
            ListPushBack(&RetList, l1->val);
            l1 = l1->next;
        }
        else
        {
            ListPushBack(&RetList, l2->val);
            l2 = l2->next;
        }
    }
    while(l1)
    {
        ListPushBack(&RetList, l1->val);
        l1 = l1->next;
    }
    while(l2)
    {
        ListPushBack(&RetList, l2->val);
        l2 = l2->next;
    }
    return RetList;
}
相关推荐
不爱吃炸鸡柳3 分钟前
5道经典贪心算法题详解:从入门到进阶
开发语言·数据结构·c++·算法·贪心算法
枫叶林FYL10 分钟前
【自然语言处理 NLP】8.3 长文本推理评估与针在大海堆任务
人工智能·算法
智者知已应修善业12 分钟前
【51单片机1,左边4个LED灯先闪烁2次后,右边4个LED灯再闪烁2次:2,接着所用灯一起闪烁3次,接着重复步骤1,如此循环。】2023-5-19
c++·经验分享·笔记·算法·51单片机
米啦啦.12 分钟前
红黑树,,
数据结构·红黑树
xiaoye-duck18 分钟前
《算法题讲解指南:优选算法-队列+宽搜》--70.N叉树的层序遍历,71.二叉树的锯齿形层序遍历,72.二叉树的最大宽度,73.在每个树行中找最大值
数据结构·c++·算法·队列
代码改善世界20 分钟前
【C++初阶】双向循环链表:List底层结构的完整实现剖析
c++·链表·list
汀、人工智能20 分钟前
[特殊字符] 第98课:数据流中位数
数据结构·算法·数据库架构··数据流·数据流中位数
Eloudy24 分钟前
不同特征值的特征向量互相正交的矩阵
人工智能·算法·机器学习
人道领域26 分钟前
【LeetCode刷题日记】:从 LeetCode 经典题看哈希表的场景化应用---数组、HashSet、HashMap 选型与算法实战
算法·leetcode·面试