2025年12月24日 - 数据结构

1、顺序表的基本操作

插入操作

删除操作

按位查找

按值查找

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

2、单链表

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

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

不带头节点的单链表

带头节点的单链表

带不带头节点的区别

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

按位序插入(带头节点)

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

指定节点的后插操作

指定节点的前插操作

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

按位序删除(带头节点)

指定节点的删除操作

按位查找

按值查找

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

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

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

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

3、双链表

双链表的初始化

双链表的插入

指定节点的后插操作

双链表的删除

双链表的遍历

循环链表

循环单链表

循环双链表

循环双链表的插入

循环双链表的删除

静态链表

定义一个静态链表

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

静态链表的初始化

静态链表的基本操作

顺序表和链表的优缺点

逻辑结构

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

物理结构/存储结构

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

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

数据的运算/基本操作

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

如何选择?

相关推荐
切糕师学AI4 小时前
环形缓冲区(Ring Buffer / Circular Buffer)详解:原理、优势、应用与高性能实现
数据结构·环形缓冲区
WolfGang0073214 小时前
代码随想录算法训练营 Day50 | 图论 part08
数据结构·算法·图论
晚枫歌F6 小时前
最小堆定时器
数据结构·算法
嫩萝卜头儿8 小时前
2 - 复杂度收尾 + 链表经典OJ
数据结构·算法·链表·复杂度
样例过了就是过了8 小时前
LeetCode热题100 分割等和子集
数据结构·c++·算法·leetcode·动态规划
木木_王8 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
北顾笙9809 小时前
day38-数据结构力扣
数据结构·算法·leetcode
m0_629494739 小时前
LeetCode 热题 100-----14.合并区间
数据结构·算法·leetcode
@小码农9 小时前
2026年3月Scratch图形化编程等级考试一级真题试卷
开发语言·数据结构·c++·算法
_日拱一卒11 小时前
LeetCode:226翻转二叉树
数据结构·算法·leetcode