数据结构 双向链表

目录

前言

双向链表的结构

双向链表的实现接口

顺序表和双向链表的优缺点分析


前言

前一节我们聊了单链表, 链表只有一个方向, 前面的节点可以找到后面的节点, 但是后面的节点找不到前面的节点, 这一节呢~, 我们就来聊一聊有两个方向的链表, 双向链表, 前面的节点可以找到后面的节点, 后面的节点也可以找到前面的节点. 让我们开始吧~~

双向链表的结构

注意:这⾥的"带头"跟前⾯我们说的"头节点"是两个概念,实际前⾯的在单链表阶段称呼不严谨,但是为了同学们更好的理解就直接称为单链表的头节点。

带头链表⾥的头节点,实际为"哨兵位",哨兵位节点不存储任何有效元素,只是站在这⾥"放哨的"

"哨兵位"存在的意义: 遍历循环链表避免死循环。

双向链表的实现接口

cpp 复制代码
typedef int LTDataType;
typedef struct ListNode
{
    struct ListNode* next; //指针保存下⼀个节点的地址
    struct ListNode* prev; //指针保存前⼀个节点的地址
    LTDataType data;
}LTNode;

//void LTInit(LTNode** pphead);
LTNode* LTInit();
void LTDestroy(LTNode* phead);
void LTPrint(LTNode* phead);
bool LTEmpty(LTNode* phead);
void LTPushBack(LTNode* phead, LTDataType x);
void LTPopBack(LTNode* phead);
void LTPushFront(LTNode* phead, LTDataType x);
void LTPopFront(LTNode* phead);
//在pos位置之后插⼊数据
void LTInsert(LTNode* pos, LTDataType x);
void LTErase(LTNode* pos);
LTNode *LTFind(LTNode* phead,LTDataType x);

顺序表和双向链表的优缺点分析

在我们正常的开发中, 使用的链表基本上都是双向链表.

从存储空间上来说, 顺序表的物理存储空间是连续的, 双向链表的物理存储空间不一定是连续的.

在随机访问层面来说, 顺序表支持随机访问, 访问的时间复杂度是O(1), 双向链表不支持随机访问, 访问的时间复杂度是O(N).

插入元素: 顺序表在任意位置插入元素, 需要移动全部元素, 双向链表只需要修改指针的指向.

相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎2 天前
LIST 的相关知识
数据结构·list
M--Y2 天前
Redis常用数据类型
数据结构·数据库·redis
༾冬瓜大侠༿2 天前
vector
c语言·开发语言·数据结构·c++·算法
汀、人工智能2 天前
[特殊字符] 第58课:两个正序数组的中位数
数据结构·算法·数据库架构··数据流·两个正序数组的中位数
liu****2 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯
汀、人工智能2 天前
[特殊字符] 第79课:分割等和子集
数据结构·算法·数据库架构·位运算·哈希表·分割等和子集
汀、人工智能2 天前
[特殊字符] 第74课:完全平方数
数据结构·算法·数据库架构·图论·bfs·完全平方数
CoderCodingNo2 天前
【GESP】C++四、五级练习题 luogu-P1177 【模板】排序
数据结构·c++·算法
汀、人工智能2 天前
[特殊字符] 第76课:单词拆分
数据结构·算法·均值算法·前缀树·trie·单词拆分
ambition202422 天前
斐波那契取模问题的深入分析:为什么提前取模是关键的
c语言·数据结构·c++·算法·图论