2025年12月24日 - 数据结构

1、顺序表的基本操作

插入操作

删除操作

按位查找

按值查找

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

2、单链表

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

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

不带头节点的单链表

带头节点的单链表

带不带头节点的区别

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

按位序插入(带头节点)

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

指定节点的后插操作

指定节点的前插操作

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

按位序删除(带头节点)

指定节点的删除操作

按位查找

按值查找

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

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

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

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

3、双链表

双链表的初始化

双链表的插入

指定节点的后插操作

双链表的删除

双链表的遍历

循环链表

循环单链表

循环双链表

循环双链表的插入

循环双链表的删除

静态链表

定义一个静态链表

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

静态链表的初始化

静态链表的基本操作

顺序表和链表的优缺点

逻辑结构

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

物理结构/存储结构

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

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

数据的运算/基本操作

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

如何选择?

相关推荐
计算机安禾几秒前
【数据结构与算法】第35篇:归并排序与基数排序
c语言·数据结构·vscode·算法·排序算法·哈希算法·visual studio
专注API从业者4 分钟前
淘宝商品详情 API 与爬虫技术的边界:合法接入与反爬策略的技术博弈
大数据·数据结构·数据库·爬虫
汀、人工智能39 分钟前
[特殊字符] 第66课:跳跃游戏
数据结构·算法·数据库架构·图论·bfs·跳跃游戏
汀、人工智能1 小时前
[特殊字符] 第70课:加油站
数据结构·算法·数据库架构·图论·bfs·加油站
favour_you___1 小时前
2026_4_8算法练习题
数据结构·c++·算法
汀、人工智能1 小时前
[特殊字符] 第57课:搜索旋转排序数组
数据结构·算法·数据库架构·图论·bfs·搜索旋转排序数组
夏乌_Wx2 小时前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
minji...3 小时前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
游乐码3 小时前
C#Queue
数据结构·游戏·c#
汀、人工智能5 小时前
[特殊字符] 第67课:跳跃游戏II
数据结构·算法·数据库架构·图论·bfs·跳跃游戏ii