2025年12月24日 - 数据结构

1、顺序表的基本操作

插入操作

删除操作

按位查找

按值查找

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

2、单链表

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

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

不带头节点的单链表

带头节点的单链表

带不带头节点的区别

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

按位序插入(带头节点)

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

指定节点的后插操作

指定节点的前插操作

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

按位序删除(带头节点)

指定节点的删除操作

按位查找

按值查找

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

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

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

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

3、双链表

双链表的初始化

双链表的插入

指定节点的后插操作

双链表的删除

双链表的遍历

循环链表

循环单链表

循环双链表

循环双链表的插入

循环双链表的删除

静态链表

定义一个静态链表

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

静态链表的初始化

静态链表的基本操作

顺序表和链表的优缺点

逻辑结构

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

物理结构/存储结构

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

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

数据的运算/基本操作

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

如何选择?

相关推荐
驭渊的小故事5 小时前
简单模板笔记
数据结构·笔记·算法
VT.馒头6 小时前
【力扣】2727. 判断对象是否为空
javascript·数据结构·算法·leetcode·职场和发展
历程里程碑8 小时前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
Sheep Shaun8 小时前
如何让一个进程诞生、工作、终止并等待回收?——探索Linux进程控制与Shell的诞生
linux·服务器·数据结构·c++·算法·shell·进程控制
Pluchon8 小时前
硅基计划4.0 简单模拟实现AVL树&红黑树
java·数据结构·算法
小龙报8 小时前
【51单片机】从 0 到 1 玩转 51 蜂鸣器:分清有源无源,轻松驱动它奏响新年旋律
c语言·数据结构·c++·stm32·单片机·嵌入式硬件·51单片机
dllxhcjla8 小时前
数据结构和算法
数据结构
历程里程碑9 小时前
普通数组----轮转数组
java·数据结构·c++·算法·spring·leetcode·eclipse
sin_hielo9 小时前
leetcode 1653
数据结构·算法·leetcode
李日灐9 小时前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树