时间:2021-05-20
双向链表和双向循环链表
和单向链表相比,多了一个前驱结点。如果他为空,那么next和prior都指向自己。而对于双循环链表,只需要最后一个元素的next指向head->next,head->next的prior指向最后一个节点即可。
插入操作
新节点s插入链表,s->next给p结点,s->prior给p->prior,然后,p->prior->next指向s,p->prior再指向s。顺序需要注意
删除操作
删除结点p。p->next->prior 指向 p->prior,p->prior->next 指向 p->next 。最后将p结点delete。
实例操作
(附截图)
注意:因为函数没有返回Node*类型,所以这里对指针进行引用,否则在退出函数的时候,并没有保存改变。如果需要删除全部链表,需要保存InitList之后的head地址,否则会遗漏一个Node结点没有删除。
代码实现:
#include<iostream>#include<cstddef>#include<cstdio>using namespace std;const int OK = 1;const int ERROR = 0;const int LETTERNUM = 26;typedef char ElemType;struct Node{ ElemType data; Node * prior;//前驱结点 Node * next;//后驱结点 };int InitList(Node *&L){ Node *p,*q; int i; L = new Node; //头结点 L->next = L->prior = NULL; p = L; //p是当前指针 for(int i=0;i<LETTERNUM;i++){ q = new Node; //q是临时指针 q->data = 'A' + i; q->prior = p; q->next = p->next; p->next = q; p = q;//指针移动 } p->next = L->next; //尾结点指向head->next(第一个有字母的地址) L->next->prior = p; return OK;}void Change(Node *&L,int i){ //移动头指针 if (i>0){ while(i--){ L = L->next; } } else if (i<0){ L = L->next ; while(i++){ L = L->prior; } } else{ L = L->next; }}int main(){ Node *head = NULL; int i,n; InitList(head); //Node *s_head = head; // 保存头结点之后删除 cout<<"输入位置:"<<endl; cin>>n; Change(head,n); for(i = 0;i<LETTERNUM;++i){ head = head->next; cout<<head->data<<" "; } cout<<endl; return 0;}感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了C++双向循环列表用法。分享给大家供大家参考。具体如下:#includeusingnamespacestd;//结构体构造链表
C语言实现单链表实现方法链表和我们之前实现过的顺序表一样,都是简单的数据结构,链表分为单向链表、双向链表、循环链表。而单向链表又分为两种实现方法,一种为带头节点
C语言数据结构双向链表的建立与基本操作双向链表比单链表有更好的灵活性,其大部分操作与线性表相同。下面总结双向链表与单链表之间的不同之处及我在实现过程中所遇到的问
C/C++双链表之逆序的实例详解一、结点结构双向链表的数据结构定义如下:typedefstructnode{ElemTypedata;structnode*pr
链表分为单链表,双向链表和循环链表,是一种链式存储结构,由一个个结点链式构成,结点包含数据域和指针域,其中单链表是只有一个指向后驱结点的指针,双向链表除头结点和