题目讲解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;
}
相关推荐
PAK向日葵12 分钟前
【算法导论】PDD 0817笔试题题解
算法·面试
地平线开发者3 小时前
ReID/OSNet 算法模型量化转换实践
算法·自动驾驶
地平线开发者3 小时前
开发者说|EmbodiedGen:为具身智能打造可交互3D世界生成引擎
算法·自动驾驶
星星火柴9364 小时前
关于“双指针法“的总结
数据结构·c++·笔记·学习·算法
艾莉丝努力练剑5 小时前
【洛谷刷题】用C语言和C++做一些入门题,练习洛谷IDE模式:分支机构(一)
c语言·开发语言·数据结构·c++·学习·算法
闪电麦坤956 小时前
数据结构:迭代方法(Iteration)实现树的遍历
数据结构·二叉树·
C++、Java和Python的菜鸟6 小时前
第六章 统计初步
算法·机器学习·概率论
Cx330❀6 小时前
【数据结构初阶】--排序(五):计数排序,排序算法复杂度对比和稳定性分析
c语言·数据结构·经验分享·笔记·算法·排序算法
散1126 小时前
01数据结构-Prim算法
数据结构·算法·图论
起个昵称吧7 小时前
线程相关编程、线程间通信、互斥锁
linux·算法