线性表的链式存储结构实验报告.doc

上传人:灯火****19 文档编号:135095334 上传时间:2020-06-12 格式:DOC 页数:8 大小:94.51KB
返回 下载 相关 举报
线性表的链式存储结构实验报告.doc_第1页
第1页 / 共8页
线性表的链式存储结构实验报告.doc_第2页
第2页 / 共8页
线性表的链式存储结构实验报告.doc_第3页
第3页 / 共8页
线性表的链式存储结构实验报告.doc_第4页
第4页 / 共8页
线性表的链式存储结构实验报告.doc_第5页
第5页 / 共8页
点击查看更多>>
资源描述

《线性表的链式存储结构实验报告.doc》由会员分享,可在线阅读,更多相关《线性表的链式存储结构实验报告.doc(8页珍藏版)》请在金锄头文库上搜索。

1、实验报告课程名称:数据结构与算法分析实验名称:链表的实现与应用实验日期:2015.01.30 班级: 数媒1401 姓名: 范业嘉 学号 1030514108 一、实验目的 掌握线性表的链式存储结构设计与基本操作的实现。二、实验内容与要求定义线性表的链式存储表示; 基于所设计的存储结构实现线性表的基本操作; 编写一个主程序对所实现的线性表进行测试;线性表的应用:设线性表L1和L2分别代表集合A和B,试设计算法求A和B的并集C,并用 线性表L3代表集合C;(选做)设线性表L1和L2中的数据元素为整数,且均已按值非递减有序排列,试设计算法对L1和L2进行合并,用线性表L3保存合并结果,要求L3中的

2、数据元素也按值非递减有序排列。 设计一个一元多项式计算器,要求能够:输入并建立多项式;输出多项式;执行两个多项式相加;执行两个多项式相减;(选做)执行两个多项式相乘。三、数据结构设计 1.按所用指针的类型、个数、方法等的不同,又可分为: 线性链表(单链表) 静态链表 循环链表 双向链表 双向循环链表2.用一组任意的存储单元存储线性表中数据元素,用指针来表示数据元素间的逻辑关系。四、算法设计1.定义一个链表void creatlist(Linklist &L,int n)int i;Linklist p,s;L=(Linklist)malloc(sizeof(Lnode);p=L;L-next=

3、NULL;for(i=0;idata);s-next=NULL;p-next=s; p=s;2. (1)两个链表的合并void Mergelist(Linklist &La,Linklist &Lb,Linklist &Lc)Linklist pa,pb,pc;pa=La-next;pb=Lb-next;Lc=pc=La;while(pa&pb)if(pa-datadata)pc-next=pa;pc=pa;pa=pa-next;else pc-next=pb;pc=pb;pb=pb-next;pc-next=pa?pa:pb;free(Lb);(2) 两个链表的并集Linklist unio

4、nlist(Linklist &La,Linklist &Lb)Linklist p1,p2,head,q,s;int flag;head=q=(Linklist)malloc(sizeof(Lnode);p1=La-next;while(p1)flag=0;p2=Lb-next;while(p2)if(p1-data=p2-data)flag=1;break;p2=p2-next;if(flag=0)s=(Linklist)malloc(sizeof(Lnode);s-data=p1-data;q-next=s;q=s;p1=p1-next; q-next=Lb-next;return he

5、ad;3. (1)一元多项式的加法List addpoly(List pa,List pb) /一元多项式的加法int n;List pc,s,p;pa=pa-next;pb=pb-next;pc=(List)malloc(sizeof(struct Linklist);pc-next=NULL;p=pc;while(pa!=NULL&pb!=NULL)if(pa-expnpb-expn)s=(List)malloc(sizeof(struct Linklist);s-expn=pa-expn;s-coef=pa-coef;s-next=NULL;p-next=s;p=s;pa=pa-next

6、;else if(pa-expnexpn)s=(List)malloc(sizeof(struct Linklist);s-expn=pb-expn;s-coef=pb-coef;s-next=NULL;p-next=s;p=s;pb=pb-next;elsen=pa-coef+pb-coef;if(n!=0)s=(List)malloc(sizeof(struct Linklist);s-expn=pa-expn;s-coef=n;s-next=NULL;p-next=s;p=s;pb=pb-next;pa=pa-next;while(pa!=NULL)s=(List)malloc(size

7、of(struct Linklist);s-expn=pa-expn;s-coef=pa-coef;s-next=NULL;p-next=s;p=s;pa=pa-next;while(pb!=NULL)s=(List)malloc(sizeof(struct Linklist);s-expn=pb-expn;s-coef=pb-coef;s-next=NULL;p-next=s;p=s;pb=pb-next;return pc;(2) 一元多项式的减法List subpoly(List pa,List pb) /一元多项式的减法int n;List pc,s,p;pa=pa-next;pb=p

8、b-next;pc=(List)malloc(sizeof(struct Linklist);pc-next=NULL;p=pc;while(pa!=NULL&pb!=NULL)if(pa-expnpb-expn)s=(List)malloc(sizeof(struct Linklist);s-expn=pa-expn;s-coef=pa-coef;s-next=NULL;p-next=s;p=s;pa=pa-next;else if(pa-expnexpn)s=(List)malloc(sizeof(struct Linklist);s-expn=pb-expn;s-coef=-pb-coe

9、f;s-next=NULL;p-next=s;p=s;pb=pb-next;elsen=pa-coef-pb-coef;if(n!=0)s=(List)malloc(sizeof(struct Linklist);s-expn=pa-expn;s-coef=n;s-next=NULL;p-next=s;p=s;pb=pb-next;pa=pa-next;while(pa!=NULL)s=(List)malloc(sizeof(struct Linklist);s-expn=pa-expn;s-coef=pa-coef;s-next=NULL;p-next=s;p=s;pa=pa-next;wh

10、ile(pb!=NULL)s=(List)malloc(sizeof(struct Linklist);s-expn=pb-expn;s-coef=-pb-coef;s-next=NULL;p-next=s;p=s;pb=pb-next;return pc;(3) 一元多项式的乘法void mulpolyn(polynomail pa,polynomail pb,polynomail &pc) LNode *p,*q,*s,*hc;p=pa-next;q=pb-next;hc=pc;while(p!=NULL) while(q!=NULL) s=(polynomail)malloc(sizeo

11、f(LNode);hc-next=s;hc=hc-next;hc-coef=q-coef*p-coef;hc-expn=q-expn+p-expn;q=q-next;p=p-next;q=pb-next;hc-next=NULL;5、 测试结果2.3.六、心得体会(包括对于本次实验的小结,实验过程中碰到的问题等) 1.首先书上给的链表输入是倒序的,写的时候想都没想就抄上去了,结果运行时发现问题,可是上网百度依然没有把问题解决,导致最后输出链表倒序的,并且链表的合并并集依旧是倒序的。 2.当写一元多项式的加减时,前提是弄清楚各种情况,系数相同时就相加减,系数不同就保留原有多项式;当系数相加减为0时,就free这个节点。在做减法时,我考虑到了减数与被减数之间的关系。 3.在做多项式时,我准备按照书上的算法一个一个写小函数,结果到最后发现写不下去了,就去问问同学和上网看看,结果感觉写这个数据结构的程序其实不必想麻烦了,只是指针,数组的高级运用。 8 / 8

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 办公文档 > 总结/报告

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号