1、DestroyList(&初始条件:有序表L已存在。操作结果:销毁有序表L。ListLength(L)1.有序表的抽象数据类型定义为返回有序表L的长度。ListEmpty(L)若有序表L为空表,则返回True,否则返回False。GetElem(L,pos)若1=pos=Length(L),则返回表中第pos个元素。LocateElem(L,e,&q)若有序表L中存在元素e,则q指示L中第一个值为e的元素的位置,并返回函数值TRUE;否则q指示第一个大于e的元素的前驱的位置,并返回函数值FALSE。ListTraverse(q,visit()有序表L已存在,q指示L中一个元素。依次对L中q指示
2、的元素开始的每个元素调用函数visit()。ADT OrderdeList2集合的抽象数据表类型定义为:ADT setD=ai|ai为小写英文字母且互不相同,i=1,s,.n,0=ndata=e;p-next=NULL; return TRUE;void FreeNode(LinkType &p)LinkType Copy (LinkType p) s=(LinkType)malloc(sizeof(NodeType);if(!s)return NULL;s-data=p-data; s-return s;ElemType Elem(LinkType p)LinkType SuccNode(L
3、inkType p)typedef struct LinkType head,tail; int size; OrderedLise;有序链表的基本操作设置如下:bool InitList(OrderedLise &L);void DestroyList(OrderedLise &bool ListEmpty(OrderedLise L);int ListLength(OrderedLise L);LinkType GetElemPos(OrderedLise L,int pos);bool LocateElem(OrderedLise L, ElemType e,LinkType &q);v
4、oid Append(OrderedLise &L,LinkType s);void InsertAfter(OrderedLise &L,LinkType q,LinkType s);void ListTraverse(LinkType p,status(*visit)(LinkType q);BOOL InitList(OrderedLise &if(MakeNode(head,)L.tail=L.head; L.size=0;return TRUE;else L.head=NULL;return FALSE;/InitListp=L.head;while(p)q=p;p=SuccNode
5、(p);FreeNode(q);L.head=L.tail=NULL;/DestroyListLinkType GetElemPos(OrderedList L, int pos )if (! L.head / posL.size ) return NULL;else if( pos = L.size ) return L.tail;else p=L.head-next; k=1;while(p&k /pre指向*p的前驱,p指向第一个元素结点while (p&datanext =s;else L.head-next=s;L.tail=s; L.size+;/Appendvoid Insert
6、After(Orderlist&L, linkType q, LinkType s)if(L.head&q&next=q- q-if(L.tail=q)L.tail=s;L.size+; /InserAftervoid ListTraverse(LinkType p, status(*visit)(LinkType)while(p)viset(p); p=SuccNode(p);/ListTraverse3.集合typedef OrderedList OrderedSet;集合类型的基本操作的类C伪码描述如下:void CreateSet(OrderedSer&T,char*s)/生成由串s中
7、小写字母构成的集合T,IsLower 是小写字母判别函数if (InitList(T)/for (i=1; i=length(s); i+)if(islower(si)&!LocateElem(T,si,p)/if(MakeNode(q,si) InsertAfter(T,P,q);/CreateSetvoid DestroySet(OrderedSer&DestroyList(T);void Union(OrderedSet &T,OrderedSet S1,OrderedSet S2)if(InitList(T)p1=GetElemPos(S1,1); p2=GetElemPos(S2,1
8、);while(p1&p2)c1=Elem(p1); c2=Elem(p2);if(c1c2)p2=SuccNode(p2);void Difference(OrderedSet &c2) Append(T,Copy(p1); p1=SuccNode(p1);c2) p2=SuccNode(p2);else p1=SuccNode(p1); p2=SuccNode(p2);void WriteSetElem(linkTypep)printf(,); WriteElem(Elem(p);void printSet(OrderedSet T)p=GetElempos(t,1);if(p) Writ
9、eElem(Elem(p);ListTraverse(p,WriteSetElem);4.主函数和其他函数的伪码算法void main()Initilization();do ReadCommand(cmd);Interpret(cmd);while(cmd!=qcmd!Qvoid Initialization()clrser();在屏幕上方显示操作命令清单:MakeSet1-1 MakeSet2-2 Union-u Intersaction-i Difference-d Quit-q;在屏幕下方显示操作命令提示框;CreateSet(Set1, PrintSet(Set1);CreateSe
10、t(Set2,void ReadCommand(char cmd)显示键入操作命令符的提示信息;do cmd=getche();while(cmd 12UiIdD);void Interpret(char cmd)switch(cmd)case:显示以串的形式键入集合元素的提示信息;scanf(v);CreatSet(Set1,v); PrintSet(set1);break;CreatSet(Set2,v); PrintSet(set2);uUnion(Set3,Set1,Set2);printSet(Set3);DestroyList(Set3);Intersaction(Set3,Set
11、1,Set2);Set3Difference(Set3,Set1,Set2);/Interpret四、调试分析1.由于对集合的三种运算推敲不足,在有序链表类型的早期版本未设置尾指针和Append操作,导致算法低效。2.刚开始是曾忽略了一些变量参数的标识“&”,是调试程序时费时不少。今后应重视确定参数的变量和赋值属性的区别和标识。3.本程序的模板划分比较合理,且尽可能将指针的操作装在结点和链表的两个模块中,致使集合模块的调试比较顺利。反之,如此划分的模块并非完全集合,因为在实现集合操作的编码中仍然需要判别指针是否为空。按理,两个链表的并、交和差的操作也应封装在链表的模块中,而在集合的模块中,只要
12、进行相应的应用即可。4.算法的时空分析1)由于有序表采用带头结点的有序单链表,并增设尾指针和表的长度两个标识,各种操作的算法时间复杂度比较合理。InitList,ListEmpty,Listlength,Append和InsertAfter以及确定链表中第一个结点和之后一个结点的位置都是O(1)的,DestroyList,LocateElem 和TraverseList几确定链表中间结点的位置等则是O(n)的,n为链表长度。2)基于有序链表实现的有序集的各种运算和操作的时间复杂度分析如下:构造有序集算法CreateSet读入n个元素,逐个用LocateElem判定不在当前集合中及确定插入位置后
13、,才用InsertAfter插入到有序集合中,所以时间复杂度是O(n2)。求并集算法Union利用集合的“有序性”将两个集合的m+n个元素不重复地依次利用APPend插入到当前并集的末尾,故可在O(m+n)时间完成。可对求交集算法Intersection和求差集算法Difference 作类似地分析,它们也是O(m+n)。销毁集合算法DestorySet和显示集合算法PruntSet都是对每个元素调用一个O(1)的函数,因此都是O(n)的。除了构造有序集算法CreateSet用一个串变量读入 个元素,需要O(n) 的辅助空间外,其余算法使用的辅助空间与元素个数无关,即是O(1) 的。5.本实习
14、作业采用数据抽象的程序设计方法,将程序划分为四个层次结果:元素结点,有序链表、有序集和主控模块,使得设计时思路清晰,实现时调试顺利,各模块具有较好的可重用性,确实得到了一次良好的程序设计训练。六、测试结果执行命令1:键入magazine后,构造集合Set1:a,e,g,I,m,n,z执行命令2:键入paper后,构造集合Set2:a,p,e,r执行命令u:构建集合Set1和Set2的并集:a,e,g,i,m,n,p,r,z执行命令i:构建集合Set1和Set2的交集:a,e执行命令d:构建集合Set1和Set2的差集:g,I,m,n,z键入012oper4a6tion89后,构造集合Set1:a,e,I,n,o,p,r,t键入errordata后,构造集合Set2:a,d,e,o,r,ta,d,e,i,n,o,p,r,ta,e,o,r,ti,n,p
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1