题目讲解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;
}
相关推荐
new coder40 分钟前
[算法练习]Day 7: 变长滑动窗口
数据结构·算法·leetcode
艾醒1 小时前
探索大语言模型(LLM): 大模型应用与对应的硬件选型一览表
算法
隐语SecretFlow1 小时前
【隐语SecretFlow】 Unbalanced PSI Benchmark性能测试报告
算法·安全·开源
wuqingshun3141591 小时前
蓝桥杯 取球博弈
算法·职场和发展·蓝桥杯
一水鉴天1 小时前
整体设计 逻辑系统程序 之20 程序设计 含分层架构、CNN 数据处理支撑、监督闭环与多场景交付物 之1 cnn_project
数据库·人工智能·算法
渡我白衣2 小时前
深度学习优化算法深入分析:从 SGD 到 LAMB
人工智能·深度学习·算法
2401_877274242 小时前
vector、list、deque的差异
数据结构·list
earthzhang20212 小时前
【1008】计算(a+b)/c的值
c语言·数据结构·c++·算法·青少年编程
dlraba8022 小时前
YOLO 目标检测算法全解析:原理、分类与性能指标
算法·yolo·目标检测
jllllyuz2 小时前
基于K近邻(KNN)算法的高光谱数据分类MATLAB实现
算法·matlab·分类