网站大量收购独家精品文档,联系QQ:2885784924

顺序表的应用.doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
. . 实验一 顺序表的应用 一、实验目的 1. 掌握线性表的顺序存储结构的存储特点与操作特点。 2. 掌握顺序表的存储表示与基本操作的实现方法。 3. 熟悉顺序表的基本应用。 4. 了解抽象数据类型的定义、表示与实现的含义。 二、实验内容 按如下要求编写程序,进行调试,写出调试正确的源代码,给出测试结果。 实现线性表在顺序存储结构下的存储表示和基本操作,并应用抽象数据类型线性表完成如下操作: 1.分别创建两个空的线性表L1、L2; 2.分别将若干元素插入到L1、L2中,输出操作后表L1和L2的内容; 3. 实现两表的合并操作:L1=L1∪L2,输出合并后表L1的内容。 4. 实现两表的求差操作:L1=L1-L2,输出求差后表L1的内容。 三、实验结果 源代码: #includeiostream.h #includestdlib.h #define OK 1 #define TRUE 1 #define FALSE 0 #define ERROR 0 #define OVERFLOW -2 #define LIST_INIT_SIZE 100 #define LISTINCREMENT 10 typedef int Status; typedef int ElemType; typedef struct//存储表示 { ElemType *elem; int length; int listsize; }SqList; //基本操作的函数声明 Status InitList_Sq(SqList L); Status ListInsert_Sq(SqList L,int i,ElemType e); Status equal(ElemType a,ElemType b); Status GetElem_Sq(SqList L,int i,ElemType e); int ListLength_Sq(SqList L); void Unoin(SqList La,SqList Lb); void cha(SqList La,SqList Lb); int LocateElem_Sq(SqList L,ElemType e,Status(*compare)(ElemType,ElemType)); //基本操作的算法实现 Status InitList_Sq(SqList L) { L.elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.length=0; L.listsize=LIST_INIT_SIZE; return OK; } Status ListInsert_Sq(SqList L,int i,ElemType e) { ElemType *newbase,*p,*q; if(i1||iL.length+1) return ERROR; if(L.length=L.listsize) { newbase=(ElemType *)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType)); if(!newbase) exit(OVERFLOW); L.elem=newbase; L.listsize+=LISTINCREMENT; } q=(L.elem[i-1]); for(p=(L.elem[L.length-1]);p=q;--p) *(p+1)=*p; *q=e; ++L.length; return OK; } Status ListDelete_Sq(SqList L,int i,ElemType e) { ElemType *p,* q; if((i1)||(iL.length)) return ERROR; p=(L.elem[i-1]); e=*p; q=L.elem+L.length-1; for(++p;p=q;++p) *(p-1)=*p; --L.length; return OK; } void cha(SqList La,SqList Lb) { int la_len,lb_len,i,e; la_len=ListLength_Sq(La); lb_len=ListLength_Sq(Lb); for(i=1;i=lb_len;i++) { GetElem_Sq(Lb,i,e); if(LocateElem_Sq(La,e,equal)) ListDelete_Sq(La,LocateElem_Sq

文档评论(0)

ygxt89 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档