




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验二:双向链表的创建,以及用双向链表实现集合见得并交和差#include#includetypedef struct DuLNode int data; struct DuLNode *prior; struct DuLNode *next; DuLNode,*DuLinkList;/建立空链表,链表头指针的data中存放了链表元素的个数。void InitList(DuLNode *p) *p=(DuLNode *)malloc(sizeof(DuLNode); (*p)-next=(*p)-prior=*p; (*p)-data=0;/在空表的基础上,创建有多个元素的链表。void create_list(DuLNode *p)int i,n,m;DuLinkList a,b;a=*p;printf(输入需要输入的元素的个数:);scanf(%d,&n); printf(n输入需要输入的元素:);for(i=0;idata=m;a-next=b;b-next=*p;b-prior=a;(*p)-prior=b;a=b;(*p)-data+;DuLinkList GetElemP(DuLinkList h,int i) int j; DuLinkList p=h; for(j=1;jnext ; return p;void Listinsert(DuLNode *m,int i,int e) DuLinkList p,q; printf(在第%d个元素前插入元素%dn,i,e); if(m-data=0)p=(DuLinkList)malloc(sizeof(DuLNode); p-data=e; m-next=p; p-prior=m; m-prior=p; p-next=m; m-data+;else q=(DuLinkList)malloc(sizeof(DuLNode); p=(DuLinkList)malloc(sizeof(DuLNode); q=GetElemP(m,i); p-data=e; p-prior=q-prior; q-prior-next=p; p-next=q; q-prior=p; m-data+;void ListDelete(DuLinkList L,int i)printf(删除第%d个元素n,i);DuLinkList p; p=GetElemP(L,i); p-prior-next=p-next; p-next-prior=p-prior;L-data -; free(p);void Display( DuLinkList L) DuLinkList p;if(L-data=0)printf(该集合为空n);elseprintf(输出该集合的元素); for(p=L-next ;p!=L;)printf(%dt,p-data); p=p-next ;printf(n该集合的元素个数:%dn,L-data);void Union(DuLinkList &la,DuLinkList lb)/求两个集合la,lb的并将结果保存在la中。int a,b,i,j,m; DuLinkList p,q;a=la-data;b=lb-data ;p=lb-next ;printf(对两个集合并操作:n);for(i=1;inext ;for(j=1;jdata !=q-data )q=q-next ;m=0;elsem=1;break;if(m=0)Listinsert(la,la-data+1 ,p-data );p=p-next ;void intersect(DuLinkList &lc,DuLinkList la,DuLinkList lb)/求两个集合la和lb的交集将结果保存在lc中。 int a,b,i,j; DuLinkList p,q;a=la-data ;b=lb-data ;p=lb-next ;for(i=1;inext ;for(j=1;jdata =q-data )Listinsert(lc,1,p-data );break;elseq=q-next;p=p-next ;void decrease(DuLinkList &ld,DuLinkList la,DuLinkList lb)/求集合la-lb的差并将结果保存在ld中。int a,b,i,j,m; DuLinkList p,q;a=la-data ;b=lb-data ;p=la-next ;for(i=1;inext ;for(j=1;jdata !=q-data)q=q-next ;m=0;elsem=1;break;if(m=0)printf(将两个集合的差插入到差集合中);Listinsert(ld,1,p-data);p=p-next ;if(ld-data=0)printf(两个集合的差为空);void main() DuLinkList la,lb,ld,lc,lj; InitList(&la) ;InitList(&lb) ;InitList(&lc) ;InitList(&ld) ;InitList(&lj) ;printf(集合la:);create_list(&la); printf(集合lb:);create_list(&lb); printf(集合lc:);create_list(&lc);printf(对la进行插入操n); Listinsert(la,1,5) ; Listinsert(la,1,2) ; Listinsert(la,2,4) ; Listinsert(la,2,3) ; Listinsert(la,1,1) ;Listinsert(la,1,6) ;printf(对lb进行插入操n); Listinsert(lb,1,7) ; Listinsert(lb,1,9) ; Listinsert(lb,1,3) ;decrease(ld,la,lb);printf(两个集合的差集合:); Display(ld);printf(求两个集合la和lb的交集:n);intersect(lj,la,lb);/求
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025中国移动上海产业研究院博士后专项招聘笔试题库历年考点版附带答案详解
- 2025中国电信安全公司春季校园招聘笔试题库历年考点版附带答案详解版
- 2025年工业0行业智能制造与自动化生产研究报告
- 2025年建筑行业智能建筑技术与建筑设计研究报告
- 2025年数字货币行业区块链技术应用与未来发展研究报告
- 2025年文化传媒行业数字内容价值创新报告
- 土地分配的协议书
- 2025年区块链行业区块链技术应用案例与未来发展前景报告
- 2025年家居装饰行业个性化定制与绿色环保发展研究报告
- 2025年石油化工行业低碳生产技术研究报告
- 白酒分销商合同协议书
- 卫星通信技术的前沿发展及其在物联网中的应用-洞察阐释
- 《医学中心肺癌诊疗》(讲课课件)
- 物流公司法人代表个人简介范文
- 规模灵活资源广域接入的新型配电系统分层分群架构与规划技术研究
- 2025年恒丰银行烟台分行招聘笔试参考题库含答案解析
- 中外建筑史课件
- 2024年度商业保理合同:保理公司与出口商之间的商业保理协议3篇
- 宣传网络安全文明上网
- 泡沫混凝土路基填筑施工方案
- 青岛 二年级 数学 上册 第4单元《8的乘法口诀》教学课件
评论
0/150
提交评论