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

总结:
1、我自己的代码能力太垃圾,要是自己苦思冥想,花了好长时间,写出一个垃圾代码,即使通过了。学习的性价比也太低了,我现在要做的是,多读代码多学习,多借鉴大佬的。

2、具体做法:a、思考四五分钟,没啥思路。找大佬的代码看懂,然后复现。b、有思路,自己写一下,遇到坎,看看大佬怎么写的,不要硬着头皮上,效率是第一位。先把这些具体实现一遍,再完完全全自己刷题!

List Merge( List L1, List L2 )
{
    List pa, pb, pc, L;
    L=(List)malloc(sizeof(struct Node));
    pa=L1->Next;
    pb=L2->Next;
    pc=L;
    
    while(pa&&pb)
    {
        if(pa->Data>=pb->Data)
        {
            pc->Next=pb;
            pc=pb;
            pb=pb->Next;
        }
        else
        {
            pc->Next=pa;
            pc=pa;
            pa=pa->Next;
        }
    }
    pc->Next=pa?pa:pb;
    L1->Next=NULL;
    L2->Next=NULL;
    
    return L;
}

写于2021-3-26 20:48


题目:L1和L2是给定的带头结点的单链表,其结点存储的数据是递增有序的;函数Merge要将L1和L2合并为一个非递减的整数序列。应直接使用原序列中的结点,返回归并后的带头结点的链表头指针S。

思路:返回的链表S的第一个节点的元素,应是L1和L2中所有元素中最小的元素。而L1与L2中最小的元素是L1中的第一个节点元素或L2中第一个节点元素,故返回的链表S的第一个元素应该是上述两个元素中较小者。

List Merge( List L1, List L2 )
{
    List S=(List)malloc(sizeof(struct Node)),tepS,tail=S;//可以把teps和tail合并成一个,但这样写起来过于凌乱
    while(L1->Next!=NULL&&L2->Next!=NULL){//可改为L->Next&&L2->Next
        if(L1->Next->Data<L2->Next->Data){
            tepS=L1->Next;
            L1->Next=L1->Next->Next;
            tepS->Next=NULL;
        }
        else{
            tepS=L2->Next;
            L2->Next=L2->Next->Next;
            tepS->Next=NULL;
        }
        tail->Next=tepS;
        tail=tepS;
    }
    //下面两个while可以改为tail->Next=L1->Next?L1->Next:L2->Next;
    while(L1->Next!=NULL){
        tepS=L1->Next;
        L1->Next=L1->Next->Next;
        tepS->Next=NULL;
        tail->Next=tepS;
        tail=tepS;
    }
    while(L2->Next!=NULL){
        tepS=L2->Next;
        L2->Next=L2->Next->Next;
        tepS->Next=NULL;
        tail->Next=tepS;
        tail=tepS;
    }
    L1->Next=NULL;
    L2->Next=NULL;
    return S;
}

写于 2021-03-28 17:57


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值