两个单链表元素交叉合并

设带头结点的线性单链表A={a1,a2,…,am},B={b1,b2,…,bn} 。试编写算法按下列规则合并A、B为线性单链表C,使得

     C={a1,b1,a2,b2,...am,bm,...,bn} , m<=n
     或者
     C={b1,a1,b2,a2,...,bn,an,...,am} ,   m>n

函数接口定义:

LinkList CombineList(LinkList La,LinkList Lb);

其中 La 和 Lb 都是用户传入的参数,分别为待合并单链表的头指针。函数须返回合并后的单链表的头指针。

裁判测试程序样例:

#include <stdio.h>
#include <stdlib.h>
typedef int DataType;
typedef struct node 
{
    DataType data;
    struct node *next;
}LNode,*LinkList;

LinkList CreatLinkList();  //创建带头结点单链表,并返回头指针。
void PrintLinkList(LinkList H);//依次输出单链表H中各个元素结点,若为空表则输出NONE。
LinkList CombineList(LinkList La,LinkList Lb);
main()
{
    LinkList la,lb;
    la = CreatLinkList();
    lb = CreatLinkList();
    la=CombineList(la,lb);
    PrintLinkList(la);
}

LinkList CreatLinkList()
{
    int n,i;
    LNode *nw,*rear=NULL,*head=NULL;
    head=(LNode*)malloc(sizeof(LNode));
    rear=head;
    scanf("%d",&n);//接收结点总数
    for(i=0;i<n;i++)
    {
        nw=(LNode*)malloc(sizeof(LNode));
        scanf("%d",&nw->data);
        rear->next=nw;
        rear=nw;
    }
    rear->next=NULL;
    return head;
}

void PrintLinkList(LinkList H)
{
    LNode *p;
    if(!(H->next))
    {    
        printf("NONE\n");
        return;
    }
    for(p=H->next;p;p=p->next)
        printf("%d ",p->data);
    printf("\n");
}


/* 请在这里填写答案 */

输入样例:
在这里给出一组输入。例如:

4
1 2 3 4
6
11 22 33 44 55 66
结尾无空行

输出样例:
在这里给出相应的输出。例如:

1 11 2 22 3 33 4 44 55 66 
结尾无空行
LinkList CombineList(LinkList La,LinkList Lb)
{
    LNode *p,*q,*r;
    LinkList Lc;//建立头指针
    int m=0,n=0;
    p = La->next;
    q = Lb->next;
  
    while(p)
    {
        ++m;
        p = p->next;//遍历La链表,求出La的长度
    }
    while(q)
    {
        ++n;
        q = q->next;//遍历Lb链表,求出La的长度
    }
    p = La->next;//因为遍历过后p,q都为空,所以需要让他们重新指向第一个节点
    q = Lb->next;
    
    if(m <= n)
    {
    	Lc = La;//m <= n,说明此时La链表比Lb链表短,那么先从La开始,
        r = Lc;          让Lc指向La所指的,就是说从La开始,就不用申请空间
                         建立新的链表了
        while(p && q)
        {
            r->next = p;//有头节点,r就只向p,然后p后移,r再指向q,q后移
            r = p;        直到p为空,因为p短,先结束
            p = p->next;
            r->next = q;
            r = q;
            q = q->next;
        }
       
          while(q)
          {
                r->next = q;//p执行完了,剩下的都是q
                r = q;
                q = q->next;
           }
          free(Lb);  
    }
    else
    {
    	Lc = Lb;
        r = Lc;
        while(p && q)
        {
            r->next = q;
            r = q;
            q = q->next;
            r->next = p;
            r = p;
            p = p->next;
           
        }
        
        while(p)
        {
            r->next = p;
            r = p;
            p = p->next;
        }
        free(La);
    }

    return (Lc);
}    
  • 7
    点赞
  • 30
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值