| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 419 人关注过本帖
标题:合并两个单链表的问题
取消只看楼主 加入收藏
guangyulou
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2011-12-9
结帖率:0
收藏
已结贴  问题点数:20 回复次数:0 
合并两个单链表的问题
#include<stdio.h>
#include<malloc.h>

typedef struct LNode
{
    int data;
    struct LNode *next;
}LNode,*LinkList;

int CreateLinkList(LinkList &L,int n)
{
    LinkList p,q;
    int a,i;
    L=(LinkList)malloc(sizeof(LNode));
    L->next=NULL;
    p=(LinkList)malloc(sizeof(LNode));
    p=L;
    for(i=0;i<n;i++)
    {
        q=(LinkList)malloc(sizeof(LNode));
        scanf("%d",&a);
        q->data=a;
        q->next=p->next;
        p->next=q;
        p=q;
    }
    return 1;
}

int Load_Sq(LinkList &L)
{
    LinkList p=L;
    while(p->next!=NULL)
    {
        p=p->next;
        printf("%d ",p->data);
    }
    return 1;
}

int MergeLinkList(LinkList &Lc,LinkList &La,LinkList &Lb)
{
    LinkList pa=La->next,pb=Lb->next,pc;
    Lc=pc=La;
    while(pa&&pb)
    {
        if(pa->data<=pb->data)
        {pc->next=pa;pc=pa;pa=pa->next;}
        else
        {pc->next=pb;pc=pb;pb=pb->next;}
    }
    if(pa)
        pc->next=pa;
    if(pb)
        pc->next=pb;
    return 1;
}

int main()
{
    LinkList La,Lb,Lc;
    int i,a,b;
    scanf("%d",&a);
    CreateLinkList(La,a);
    printf("The list a is:\n");
        Load_Sq(La);
    printf("\n");
    scanf("%d",&b);
    CreateLinkList(Lb,b);
    printf("the list b is\n");
    Load_Sq(Lb);
    printf("\n");
    MergeLinkList(Lc,La,Lb);
    Load_Sq(La);
    printf("\n");
    Load_Sq(Lb);
    printf("\n");
    Load_Sq(Lc);
    return 1;
}



合并以后La和Lb的输出怎么变了?
搜索更多相关主题的帖子: return include 
2011-12-09 18:10
快速回复:合并两个单链表的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025616 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved