




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验报告课程名称:数据结构与算法分析实验名称:链表的实现与应用实验日期:班级:数媒1401姓名:范业嘉学号一、实验目的掌握线性表的链式存储结构设计与基本操作的实现。二、实验内容与要求定义线性表的链式存储表示;基于所设计的存储结构实现线性表的基本操作;编写一个主程序对所实现的线性表进行测试;线性表的应用:设线性表L1和L2分别代表集合A和B,试设计算法求A和B的并集C,并用线性表L3代表集合C;(选做)设线性表L1和L2中的数据元素为整数,且均已按值非递减有序排列,试设方t算法对L1和L2进行合并,用线性表L3保存合并结果,要求L3中的数据元素也按值非递减有序排列。设计一个一元多项式计算器,要求
2、能够:输入并建立多项式;输出多项式;执行两个多项式相加;执行两个多项式相减;(选做)执行两个多项式相乘。三、数据结构设计1.按所用指针的类型、个数、方法等的不同,又可分为:线性链表(单链表)静态链表循环链表双向链表双向循环链表2.用一组任意的存储单元存储线性表中数据元素,用指针来表示数据元素间的逻辑关系。四、算法设计1 .定义一个链表voidcreatlist(Linklist&L,intn)inti;Linklistp,s;L=(Linklist)malloc(sizeof(Lnode);P=L;L->next=NULL;for(i=0;i<n;i+)s=(Linklis
3、t)malloc(sizeof(Lnode);scanf("%d",&s->data);s->next=NULL;p->next=s;p=s;2. (1)两个链表的合并voidMergelist(Linklist&La,Linklist&Lb,Linklist&Lc)Linklistpa,pb,pc;pa=La->next;pb=Lb->next;Lc=pc=La;while(pa&&pb)if(pa->data<=pb->data)pc->next=pa;pc=pa;pa
4、=pa->next;elsepc->next=pb;pc=pb;pb=pb->next;pc->next=pa?pa:pb;free(Lb);(2)两个链表的并集Linklistunionlist(Linklist&La,Linklist&Lb)Linklistp1,p2,head,q,s;intflag;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
5、;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;returnhead;3. (1)一元多项式的加法Listaddpoly(Listpa,Listpb)/一元多项式的加法intn;Listpc,s,p;pa=pa->next;pb=pb->next;pc=(List)malloc(sizeof(structLinklist);pc->next=
6、NULL;p=pc;while(pa!=NULL&&pb!=NULL)if(pa->expn>pb->expn)s=(List)malloc(sizeof(structLinklist);s->expn=pa->expn;s->coef=pa->coef;s->next=NULL;p->next=s;p=s;pa=pa->next;elseif(pa->expn<pb->expn)s=(List)malloc(sizeof(structLinklist);s->expn=pb->expn;
7、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(structLinklist);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(structLinklist);s
8、->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(structLinklist);s->expn=pb->expn;s->coef=pb->coef;s->next=NULL;p->next=s;p=s;pb=pb->next;returnpc;(2)一元多项式的减法Listsubpoly(Listpa,Listpb)/一元多项式的减法intn;
9、Listpc,s,p;pa=pa->next;pb=pb->next;pc=(List)malloc(sizeof(structLinklist);pc->next=NULL;p=pc;while(pa!=NULL&&pb!=NULL)if(pa->expn>pb->expn)s=(List)malloc(sizeof(structLinklist);s->expn=pa->expn;s->coef=pa->coef;s->next=NULL;p->next=s;p=s;pa=pa->next;)el
10、seif(pa->expn<pb->expn)(s=(List)malloc(sizeof(structLinklist);s->expn=pb->expn;s->coef=-pb->coef;s->next=NULL;p->next=s;p=s;pb=pb->next;)else(n=pa->coef-pb->coef;if(n!=0)(s=(List)malloc(sizeof(structLinklist);s->expn=pa->expn;s->coef=n;s->next=NULL;p-&
11、gt;next=s;p=s;)pb=pb->next;pa=pa->next;)while(pa!=NULL)(s=(List)malloc(sizeof(structLinklist);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(structLinklist);s->expn=pb->expn;s->coef=-pb->coef;s-&g
12、t;next=NULL;p->next=s;p=s;pb=pb->next;returnpc;(3)一元多项式的乘法voidmulpolyn(polynomailpa,polynomailpb,polynomail&pc)LNode*p,*q,*s,*hc;p=pa->next;q=pb->next;hc=pc;while(p!=NULL)while(q!=NULL)s=(polynomail)malloc(sizeof(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;五、测试结果7表表链链y锥槌ssanLaLb售.出出集并eS91'押开合喋2.3.六、心得体会(包括对于本次实验的小结,实验过程中碰到的问题等)1 .首先书上给的链表输入是倒序的,写的时候想都没想就抄上去了,结果运行时发现问题,可是上网百度依然没有把问题解决,导致最后输出链表倒
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【正版授权】 IEC 60684-2:2025 EN-FR Flexible insulating sleeving - Part 2: Methods of test
- 【正版授权】 IEC 63522-20:2025 EN-FR Electrical relays – Tests and measurements - Part 20: Mechanical endurance
- 2025年学前教育与儿童发展考试试卷及答案
- 2025年全球化与地方文化保护考试题及答案
- 2025年按摩与推拿专业考试题及答案
- 2025年茶艺师职业能力测试试卷及答案
- 万安保安考试题及答案
- 梯级城市基础设施优化补充协议
- 商住两用房产分割与资产重组投资协议
- 网络零售商网店经营权保留及数据分析服务协议
- 案例硫酸铜晶体的制备
- 铁路混凝土梁配件多元合金共渗防腐技术条件
- 土地权属争议形成成因及处理原则
- 智利地质矿产资源概况
- 北大青鸟控制器简单操作说明xin
- 酒店值班经理工作日志模板
- JJG 961-2017 医用诊断螺旋计算机断层摄影装置(CT)X射线辐射源
- 全国庙会时间表
- 江南古镇建筑的水文化生态隐喻[权威精品]
- 第二章_糖和苷
- 三视图基础版练习
评论
0/150
提交评论