资源描述:
《双向循环链表的建立插入与删除》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、创建双向循环链表的源代码:#include#include#defineOVERFLOW-2#defineERROR0#defineOK1typedefintstatus;//双向循环链表的存储结构typedefstructDuLNode{intdata;intLength;structDuLNode*prior;structDuLNode*next;}DuLNode,*DuLinkList;//构建一个空的双向循环链表voidInitList(DuLNode**p){*p=(DuLNo
2、de*)malloc(sizeof(DuLNode));if(*p){(*p)->next=(*p)->prior=*p;(*p)->Length=0;}elseexit(OVERFLOW);}//双向循环链表的创建voidCreate(DuLinkList&L,intn){//输入n个元素的值,建立带头结点的双线循环链表LDuLinkListp=L,q;inti;for(i=1;i<=n;i++){q=(DuLinkList)malloc(sizeof(DuLNode));printf("您该输入第%d个元素的值了:",i
3、);scanf("%d",&q->data);p->next=q;q->prior=p;q->next=L;L->prior=q;p=q;L->Length++;}}//结点的输出voidDisplay(DuLinkListL){DuLinkListp;printf("双向循环链表中的结点的数据为:");for(p=L->next;p->next!=L;){printf("%d",p->data);printf("、");p=p->next;}printf("%d",p->data);}intmain(){DuLinkL
4、istL;intn,i;InitList(&L);printf("你想创建几个循环节点就输入几就行啦,请输入:");scanf("%d",&n);Create(L,n);Display(L);}双向循环链表插入源代码:#include#include#defineOVERFLOW-2#defineERROR0#defineOK1typedefintstatus;//双向循环链表的存储结构typedefstructDuLNode{intdata;intLength;structDuLNod
5、e*prior;structDuLNode*next;}DuLNode,*DuLinkList;//构建一个空的双向循环链表intInitList(DuLNode**p){*p=(DuLNode*)malloc(sizeof(DuLNode));if(*p){(*p)->next=(*p)->prior=*p;(*p)->Length=0;}elseexit(OVERFLOW);}//双向循环链表的创建voidCreate(DuLinkList&L,intn){//输入n个元素的值,建立带头结点的双线循环链表LDuLinkL
6、istp=L,q;inti;for(i=1;i<=n;i++){q=(DuLinkList)malloc(sizeof(DuLNode));printf("其中第%d个元素的值为:",i);scanf("%d",&q->data);p->next=q;q->prior=p;q->next=L;L->prior=q;p=q;L->Length++;}}//查找元素的位置DuLinkListGetElemP(DuLinkListh,inti){intj;DuLinkListp=h;for(j=1;j<=i;j++)p=p->ne
7、xt;returnp;}//结点的插入statusListinsert(DuLNode*m,inti,inte){//在带头结点的双链循环线性表L中第i个位置之前插入元素e,i的合法值为1≤i≤表长DuLinkListp,q;if(i<1
8、
9、i>(m->Length))//i值不合法returnERROR;p=GetElemP(m,i);if(!p)returnERROR;q=(DuLinkList)malloc(sizeof(DuLNode));if(!q)returnOVERFLOW;q->data=e;q->prior
10、=p->prior;p->prior->next=q;q->next=p;p->prior=q;m->Length++;printf("您在双向循环链表第%d个位置之前插入了一结点元素:%d",i,e);returnOK;}//结点的输出voidDisplay(DuLinkListL)