2025年12月24日 - 数据结构

1、顺序表的基本操作

插入操作

删除操作

按位查找

按值查找

结构体不能直接用 == 进行比较

2、单链表

定义单链表时不同的声明方式

不带*表示这是一个单链表的节点,带*表示这是一个单链表

不带头节点的单链表

带头节点的单链表

带不带头节点的区别

带头结点的单链表写代码会更方便点,不带头结点的链表对第一个数据节点和后续数据节点的处理需要用不同的代码逻辑,对空表和非空表的处理需要用不同的代码逻辑。

按位序插入(带头节点)

按位序插入(不带头节点)

指定节点的后插操作

指定节点的前插操作

不遍历找他的前一个节点,而是直接新创建一个节点,和后一个节点的数据进行交换即可

按位序删除(带头节点)

指定节点的删除操作

按位查找

按值查找

尾插法建立单链表(带头节点)

创建一个临时指向表尾的指针,避免每次添加节点时都要遍历一遍前面的所有节点。

头插法建立单链表(带头节点)

头插法有个重要的应用,可以逆置链表

3、双链表

双链表的初始化

双链表的插入

指定节点的后插操作

双链表的删除

双链表的遍历

循环链表

循环单链表

循环双链表

循环双链表的插入

循环双链表的删除

静态链表

定义一个静态链表

使用数组的形式获取连续的一片存储空间(虽然是获取连续的存储空间,但是节点的顺序不是按存储顺序放置的),将每个节点分成两部分,一部分存储数据,另一部分存储下一个元素的数组下标。

静态链表的初始化

静态链表的基本操作

顺序表和链表的优缺点

逻辑结构

都属于线性表,都是线性结构

物理结构/存储结构

线性表:支持随机存取,存储密度高(不用存储下个节点的指针),大片连续空间分配不方便,改变容量不方便。

链表:离散的小空间分配方便,改变容量方便,不可随机存储,存储密度低。

数据的运算/基本操作

链表不管怎么查找都需要遍历链表

如何选择?

相关推荐
CSharp精选营5 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假8 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠9 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦16 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠17 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾17 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82117 天前
算法复键——树状数组
数据结构·算法
牛油果子哥q17 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒17 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode
WL学习笔记17 天前
单项不带头不循环链表
数据结构·链表