- 1、本文档共4页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
线性表的合并操作——链式存储
/* Note:Your choice is C IDE */
#include stdio.h
#include stdlib.h
#define ERROR 0
#define OK 1
typedef int Status;
typedef int ElemType;
typedef struct LNode
{
ElemType data;
struct LNode *next;
}LNode,*LinkList;
//初始化
Status InitList_L(LinkList *L)
{
*L=(LinkList)malloc(sizeof(LNode));
if(!*L)exit(0);
(*L)-next=NULL;
return OK;
}
//测长度
int ListLength_L(LinkList L)
{
LinkList p;
int j;
p=L-next;
j=0;
while(p)
{p=p-next;j++;}
return j;
}
//插入操作
Status ListInsert_L(LinkList L,int i,ElemType e)
{
LinkList p,s;
int j;
p=L;
j=0;
while(pji-1){p=p-next;j++;}
if(!p||ji-1) return ERROR;
s=(LinkList)malloc(sizeof(LNode));
if(!s)exit(0);
s-data=e;
s-next=p-next;
p-next=s;
return OK;
}
//删除操作
Status ListDelete_L(LinkList L,int i,ElemType *e)
{
LinkList p,q;
int j;
p=L;
j=0;
while(!pji-1){p=p-next;j++;}
if(!(p-next)||ji-1) return ERROR;
q=p-next;
*e=q-data;
p-next=q-next;
free(q);
return OK;
}
//合并操作
void MergeList_L(LinkList La,LinkList Lb,LinkList *Lc)
{
LinkList pa,pb,pc;
pa=La-next;
pb=Lb-next;
*Lc=pc=La;
while(papb)
{
if(pa-data=pb-data) {pc-next=pa;pc=pa;pa=pa-next;}
else {pc-next=pb;pc=pb;pb=pb-next;}
}
pc-next=pa?pa:pb;
free(Lb);
}
void main()
{
LinkList La,Lb,Lc,q;
ElemType e;
int i,j,a,b;
if(InitList_L(La)) printf(La:Initer is OK!\n);
else printf(error!\n);
//La的赋值
printf(please input La.length!\n);
scanf(%d,a);
printf(Please input the Las values of sq:\n);
for(i=0;ia;i++)
{
scanf(%d,e);
for(j=1,q=La-next;j=i;j++)
{
if(eq-data)break;
else q=q-next;
}
if(!ListInsert_L(La,j,e))printf(error!\n);
}
printf(La-);
q=La-next;
while(q)
{
if(q-next)printf(%d-,q-data);
else printf(%d\n,q-data);
q=q-next;
}
printf(Las length: %d\n\n,ListLength_L(La));
//Lb的赋值
if(InitList_L(Lb)) printf(Lb:Initer is OK!\n);
printf(please input Lb.length!\n);
scanf(%d,b);
printf(Please input the
文档评论(0)