【PTA】两个有序链表序列的合并

本文介绍了如何使用原节点实现ListInsert函数,将新节点插入到链表末尾,并在ListMerge函数中合并两个有序链表,通过比较节点数据进行插入操作。展示了合并过程中的逻辑和细节处理。

 

List Insert(List L3,List tmp){
//按题意,使用原结点,不能new新结点
    List L4=L3;
    while(L4->Next){
        L4=L4->Next;
    }
    //将tmp插入List最后,将tmp->Next置空
    //需要注意必须提前记住tmp下一个元素,不然没法继续访问L1,L2
    L4->Next=tmp;
    tmp->Next=NULL;
    return L3;
}

List Merge( List L1, List L2 ){
    List L3=(List)malloc(sizeof(struct Node));
    L3->Next=NULL;

//注意空表头的Next必须置空,判定程序的Print函数记住了原空表头的位置
//不然空表头仍然会指向新表元素
    List L4=L1;List L5=L2;
    L1=L1->Next;L2=L2->Next;
    L4->Next=NULL;L5->Next=NULL;

    List tmp,tmp1;
    while(L1 && L2){
        if(L1->Data<L2->Data){
            tmp=L1;
            L1=L1->Next;
            L3=Insert(L3,tmp);
        }else if(L1->Data>L2->Data){
            tmp=L2;
            L2=L2->Next;
            L3=Insert(L3,tmp);
        }else{
            tmp=L1;
            tmp1=L2;
            L1=L1->Next;
            L2=L2->Next;
            L3=Insert(L3,tmp);
            L3=Insert(L3,tmp1);
            
        }
    }

    while(L1){
        tmp=L1;
        L1=L1->Next;
        L3=Insert(L3,tmp);
    }

    while(L2){
        tmp=L2;
        L2=L2->Next;
        L3=Insert(L3,tmp);
    }


    return L3;
}

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值