浙大数据结构:02-线性结构1 两个有序链表序列的合并

数据结构MOOC

PTA习题

02-线性结构1 两个有序链表序列的合并

用p1,p2存储两个头节点。如果都为空直接返回一个空链表

否则选两条链表中第一个较小的值作为新链表第一个结点。

L1,L2后移一下,然后删除两个没有用的头节点

循环遍历,把值小的插入链表中,直到一个链表遍历完。

再把没遍历完的链表插入新链表中,最后返回头节点

cpp 复制代码
List Merge(List L1,List L2)
{
      List p1=L1,p2=L2;
List head=(List)malloc(sizeof(struct Node));
    if(p1->Next==NULL&&p2->Next==NULL)
    {
  head->Next=NULL;return head;
    }
    head->Next=L1->Next->Data>L2->Next->Data?L2->Next:L1->Next;
    List p=head;
     L1=L1->Next;L2=L2->Next;
     p1->Next=NULL;p2->Next=NULL;
    while(L1!=NULL&&L2!=NULL)
    {
     if(L1->Data<L2->Data)
     {
       head->Next=L1;
         head=head->Next;
         L1=L1->Next;
     }
        else 
        {
            head->Next=L2;
            head=head->Next;
            L2=L2->Next;
        }
    }
    if(L1)
    head->Next=L1;
    else if(L2)
        head->Next=L2;
    return p;
}
相关推荐
艾莉丝努力练剑7 分钟前
【C语言16天强化训练】从基础入门到进阶:Day 1
c语言·开发语言·数据结构·学习
亲爱的非洲野猪8 分钟前
令牌桶(Token Bucket)和漏桶(Leaky Bucket)细节对比
网络·算法·限流·服务
颖川守一12 分钟前
C++c6-类和对象-封装-设计案例2-点和圆的关系
开发语言·c++
NAGNIP23 分钟前
一文读懂LLAMA
算法
烧冻鸡翅QAQ25 分钟前
62.不同路径
算法·动态规划
番薯大佬25 分钟前
编程算法实例-冒泡排序
数据结构·算法·排序算法
queenlll27 分钟前
P2404 自然数的拆分问题(典型的dfs)
算法·深度优先
wydaicls28 分钟前
用函数实现方程函数解题
人工智能·算法·机器学习
·白小白29 分钟前
力扣(LeetCode) ——100. 相同的树(C语言)
c语言·算法·leetcode
charlee4443 分钟前
将std容器的正向迭代器转换成反向迭代器
c++