1、顺序表的基本操作
插入操作

删除操作

按位查找


按值查找

结构体不能直接用 == 进行比较
2、单链表
定义单链表时不同的声明方式
不带*表示这是一个单链表的节点,带*表示这是一个单链表

不带头节点的单链表

带头节点的单链表

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

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

指定节点的后插操作

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

按位序删除(带头节点)

指定节点的删除操作

按位查找

按值查找

尾插法建立单链表(带头节点)
创建一个临时指向表尾的指针,避免每次添加节点时都要遍历一遍前面的所有节点。

头插法建立单链表(带头节点)
头插法有个重要的应用,可以逆置链表

3、双链表
双链表的初始化

双链表的插入
指定节点的后插操作

双链表的删除

双链表的遍历

循环链表
循环单链表

循环双链表

循环双链表的插入

循环双链表的删除

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


静态链表的初始化

静态链表的基本操作

顺序表和链表的优缺点
逻辑结构
都属于线性表,都是线性结构
物理结构/存储结构
线性表:支持随机存取,存储密度高(不用存储下个节点的指针),大片连续空间分配不方便,改变容量不方便。
链表:离散的小空间分配方便,改变容量方便,不可随机存储,存储密度低。
数据的运算/基本操作



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

如何选择?
