双向链表上的插入和删除算法.pdf

双向链表上的插入和删除算法.pdf

ID:53001679

大小:110.78 KB

页数:5页

时间:2020-04-10

双向链表上的插入和删除算法.pdf_第1页
双向链表上的插入和删除算法.pdf_第2页
双向链表上的插入和删除算法.pdf_第3页
双向链表上的插入和删除算法.pdf_第4页
双向链表上的插入和删除算法.pdf_第5页
资源描述:

《双向链表上的插入和删除算法.pdf》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、编写程序,演示在双向链表上的插入和删除算法。问题分析:1、在双向链表上操作首先要生成一个双向链表:1>节点定义structDuLNode{ElemTypedata;DuLNode*prior;DuLNode*next;};2.>创建双列表L=(DuLinkList)malloc(sizeof(DuLNode));L->next=L->prior=L;3>输入链表数据;2、3、对向链表进行插入操作算法:在节点p的前面加入一个新的节点q:q=(DuLinkList)malloc(sizeof(DuL

2、Node));q->data=e;q->prior=p->prior;q->next=p;p->prior->next=q;p->prior=q;4、对双向链表进行删除操作算法删除给定节点p得到的代码如下:#include#include#defineOK1#defineERROR0usingnamespacestd;typedefintElemType;typedefintstatus;structDuLNode{ElemTypedata;DuLNode

3、*prior;DuLNode*next;};typedefDuLNode*DuLinkList;statusDuListInsert_L(DuLinkListL,inti,ElemTypee)//插入函数{DuLinkListp=L;//定义两个指向头节点的指针DuLinkListq=L;intj=0;while(p->next!=L&&jnext;j++;}if(p->next==L

4、

5、j

6、rintf("无效的插入位置!");returnERROR;}//创建新节点q,数据为e,指针为nullq=(DuLinkList)malloc(sizeof(DuLNode));q->data=e;q->prior=p->prior;q->next=p;p->prior->next=q;p->prior=q;returnOK;}statusDuListDelete_L(DuLinkListL,inti,ElemType&e)//删除{DuLinkListp=L;intj=0;while(p

7、->next!=L&&jnext;j++;}if(p->next==L

8、

9、jprior->next=p->next;p->next->prior=p->prior;e=p->data;free(p);returnOK;}intmain(){//初始化双向循环链表LDuLinkListL;L=(DuLinkList)malloc(sizeof(DuLNode));//创建空双列表头结点L->next=L->prior=L;DuLNode*p

10、,*q;ElemTypee;//给L赋初始值p=L;q=L;while(cin>>e){p->next=(DuLNode*)malloc(sizeof(DuLNode));//分配新的节点q=p;p=p->next;//p指向新的节点p->data=e;//新结点的数据域为刚输入的ep->next=L;//新结点的指针域为头结点,表示这是单链表的最后一个结点p->prior=q;L->prior=p;}//p指向头指针,逐一输出链表的每个结点的值p=L;while(p->next!=L)//输出

11、原列表{cout<next->data<<'';p=p->next;}cin.clear();//清除上一个cin的错误信息cin.ignore();//清空输入流inti;cout<<"输入待插入的元素e:";cin>>e;cout<<"输入待插入的位置i:";cin>>i;if(DuListInsert_L(L,i,e)){cout<<"插入后的双链为:";p=L;while(p->next!=L){cout<next->data<<'';p=p->next;}}printf

12、("");p=L;while(p->next!=L)//输出列表{cout<next->data<<'';p=p->next;}intk;cin.clear();//清除上一个cin的错误信息cin.ignore();//清空输入流cout<<"要删除第几个节点k:";cin>>k;if(DuListDelete_L(L,k,e)){cout<<"被删除的元素为:"<next!=L)//输出删除后的列表{c

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。