C语言如何实现双向链表和双向循环链表
发表于:2025-11-09 作者:千家信息网编辑
千家信息网最后更新 2025年11月09日,本文小编为大家详细介绍"C语言如何实现双向链表和双向循环链表",内容详细,步骤清晰,细节处理妥当,希望这篇"C语言如何实现双向链表和双向循环链表"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一
千家信息网最后更新 2025年11月09日C语言如何实现双向链表和双向循环链表
本文小编为大家详细介绍"C语言如何实现双向链表和双向循环链表",内容详细,步骤清晰,细节处理妥当,希望这篇"C语言如何实现双向链表和双向循环链表"文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。
双向链表和双向循环链表
和单向链表相比,多了一个前驱结点。如果他为空,那么next和prior都指向自己。而对于双循环链表,只需要最后一个元素的next指向head->next,head->next的prior指向最后一个节点即可。
插入操作
新节点s插入链表,s->next给p结点,s->prior给p->prior,然后,p->prior->next指向s,p->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。
p->prior->next = p->next;p->next->prior = p->prior;delete p;
实例操作
(附截图)

注意:因为函数没有返回Node*类型,所以这里对指针进行引用,否则在退出函数的时候,并没有保存改变。如果需要删除全部链表,需要保存InitList之后的head地址,否则会遗漏一个Node结点没有删除。
代码实现:
#include#include #include 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 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<<"输入位置:"< >n; Change(head,n); for(i = 0;i next; cout< data<<" "; } cout< 读到这里,这篇"C语言如何实现双向链表和双向循环链表"文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注行业资讯频道。
结点
双向
指向
环链
指针
语言
文章
内容
函数
前驱
地址
节点
移动
妥当
代码
位置
元素
单向
双循环
字母
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
警察讲网络安全
2020年网络安全周相关知识
免费梯子服务器
软件开发的原型化
苏州新品服务器供货厂
电吉他谱软件开发
为啥现在都用云服务器
存储服务器是不是网盘
指定数据库全名oracle
数据库中float长度
恐怖主义网络安全气候变化
asp 服务器配置
数据库连接会话作用
企业合作网络安全
自计算机网络技术与自动化
pl sql怎么倒数据库
软件开发用的什么笔记本电脑
网络安全设备建设方案
数据库实用程序开发
传奇怪物数据库准确
腾讯服务器怎么关闭
打印服务器连接wifi
互联网科技给我们带来的好处
网络安全技术学堂在线
望远县软件开发公司排行榜
绕过服务器缓存
浙江服务器维保云主机
黄浦区管理网络技术咨询口碑推荐
网络安全dns劫持
网络安全形势与应对心得