双链表详解:定义、存储结构与基本操作
创作时间:
作者:
@小白创作中心
双链表详解:定义、存储结构与基本操作
引用
1
来源
1.
https://wuli.wiki/online/DList.html
双链表是计算机科学中一种重要的数据结构,它在每个节点中存储了两个指针,分别指向其前一个和后一个节点。这种结构使得双链表在插入和删除操作上具有较高的效率,特别是在需要频繁进行这些操作的场景中。本文将详细介绍双链表的定义、存储结构以及基本操作的实现方法。
双链表的基本概念
双链表在竞赛中用的不多,通常是因为需要优化某些问题而使用双链表。双链表上的每个结点都有 $4$ 个值,$\mathtt{Lnext}$ 指针表示它左边的结点的下标,$\mathtt{Rnext}$ 指针表示它右边的结点的下标,其他的数组和变量和单链表的存储代表一个意思。
使用C++实现双链表
用 C++ 的指针和结构体来实现双链表:
struct Double_List
{
int value;
Double_List *prev, *next; // 左指针和右指针
};
使用数组模拟双链表
数组模拟双链表需要这么几个数组和变量:
// 为了简化代码,我们用 e 表示 value, l 表示 Lnext, r 表示 Rnext
int e[N], l[N], r[N], idx;
双链表的基本操作
双链表的基本操作主要包括:
- 在第 $k$ 个插入的数左侧插入一个数;
- 在第 $k$ 个插入的数右侧插入一个数;
- 将第 $k$ 个插入的数删除
插入操作
在第 $k$ 个插入的数的右边插入一个数:
- 第 $1$ 步:先让要插入的点的右指针指向第 $k$ 个插入的点右边的点
- 第 $2$ 步:让要插入的点的左指针指向第 $k$ 个插入的点
- 第 $3$ 步:让第 $k$ 个插入的点的右边的点的左指针指向要插入的点
- 第 $4$ 步:让第 $k$ 个插入的点的右指针指向要插入的点
// 在第 k 个插入的数的右边插入一个数
void insert(int k, int x)
{
e[idx] = x; // 赋值
r[idx] = r[k]; // 第 1 步
l[idx] = k; // 第 2 步
l[r[k]] = idx; // 第 3 步
// r[k] 是第 k 个插入的点的右边的点,
// l[r[k] 就是第 k 个插入的点的右边的点的左指针
r[k] = idx ++ ; // 第 4 步
}
// 熟练掌握了之后就可以写成一行了。
e[idx] = x, r[idx] = r[k], l[idx] = k, l[r[k]] = idx, r[k] = idx ++ ;
注意:
第 $1$ 步和第 $2$ 步的操作的位置可互换,但是第 $3$ 步和第 $4$ 步的位置不可互换。 因为如果先操作第 $4$ 步的话,r[k] 就是修改之后的值了,如果接下来再调用 l[r[k]] 就不对了。
如果想要在第 $k$ 个插入的数的左边插入一个数怎么办呢?
最直接的办法就是照着刚才的逻辑对应着再写一遍,当然还有更见简便的方法。
就是直接调用
insert(l[k + 1], x);
// 注意 k 要加 1,因为 idx 从 2 开始,所以下标也从 2 开始
删除操作
双链表的删除操作和单链表的删除类似
- 让第 $k$ 个插入的点的左边的结点的右指针指向第 $k$ 个插入的点的右边的结点
- 让第 $k$ 个插入的点的右边的结点的左指针指向第 $k$ 个插入的点的左边的结点
对应到代码上:
// 删除第 k 个插入的点
void remove(int k)
{
r[l[k]] = r[k], l[r[k]] = l[k];
}
// l[k] 为第 k 个插入的点的左边的结点,r[l[k]] 为第 k 个插入的点的左边的结点的右指针
// r[k] 为第 k 个插入的点的右边的结点,l[r[k]] 为第 k 个插入的点的右边的结点的左指针
这样,双链表的基本操作就讲完了。
热门推荐
阳虚的人都有什么表现?该怎么调养?
什么是金融模型?金融模型的应用范围有哪些?
减重总失败?你可能踩了这9个坑!专家揭秘科学瘦身法则
研究发现:新冠病毒对大脑造成损害,影响认知功能
如何提升前端开发技能:从学习到实践的全方位指南
阿托伐他汀天天吃,牢记“3要3不要”原则,医生提醒
黄豆芽放一天后变绿是什么原因?
养鸭过程中常见的5种传染疾病及防治方法
被发现了!萧山这里有座“天空之城”!
基层法律服务工作者的工作环境怎么样?
饥荒游戏新手如何配置电脑?配置电脑有哪些要点?
南宁房产市场前景分析及投资建议
对比分析热门手机与平板电脑性能:如何挑选最适合自己的电子设备
葵花籽种植在几月?这份种植指南请收好
抑郁症患者常做的梦是什么样的?夜晚的梦境是否令人恐惧?
成都新津区红石涵养湿地公园:一座集休闲娱乐于一体的生态公园
老年人夜尿频繁怎么回事如何治疗
养鸭必备:常见疾病识别与防治宝典
中国建研院原创设计的“朝阳公园奥运沙滩排球馆更新改造项目”首赛获多家央媒关注
头皮发凉是什么原因
信用卡逾期银行说面临诉讼?一文详解法律风险与应对策略
提升含“科”量 展望新前景——香港国际金融中心新观察
中医视角下的男性脱发原因与疗法
腰椎手术术后饮食指南:四个基本原则助力快速康复
《斗罗大陆:逆转时空》零氪玩家流派选择攻略
寒香蜜葡萄:冬日里的独特美味
家庭宽带办理指南:从选择服务商到日常维护的全方位注意事项与建议
痰是怎么产生出来的
美国本科留学费用详解:四年学费与生活成本全解析
NBA历史前十球星,谁的传奇更震撼?附CCTV5、CCTV5+节目表