浙大数据结构: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;
}
相关推荐
Live&&learn25 分钟前
数据结构vs 内存结构
数据结构·操作系统·内存结构
buyue__27 分钟前
C++实现数据结构——队列和栈
数据结构
执笔论英雄36 分钟前
【大模型训练】forward_backward_func返回多个micro batch 损失
开发语言·算法·batch
太理摆烂哥44 分钟前
哈希表实现
数据结构·哈希算法·散列表
序属秋秋秋2 小时前
《Linux系统编程之进程基础》【进程优先级】
linux·运维·c语言·c++·笔记·进程·优先级
草莓熊Lotso2 小时前
C++ STL map 系列全方位解析:从基础使用到实战进阶
java·开发语言·c++·人工智能·经验分享·网络协议·everything
_F_y2 小时前
C++IO流
c++
草莓熊Lotso2 小时前
《算法闯关指南:优选算法--模拟》--41.Z 字形变换,42.外观数列
开发语言·c++·算法
啊吧怪不啊吧2 小时前
算法王冠上的明珠——动态规划之斐波那契数列问题
大数据·算法·动态规划
AA陈超8 小时前
ASC学习笔记0020:用于定义角色或Actor的默认属性值
c++·笔记·学习·ue5·虚幻引擎