




已阅读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年安徽省第七届粮食行业职业技能大赛(粮油保管员赛项)备考试题库(含答案)
- ECMO培训课件教学课件
- 白银租赁合同协议
- 电气技术员试题及答案
- 航材包装、运输管理程序
- 静压植桩机钢管桩施工技术
- 2024年档案管理员考试全新试题及答案
- 2024年施工员题库含完整答案(必刷)
- 2025年保安证考试答题技巧与试题答案
- 道路施工流程讲解
评论
0/150
提交评论