1.线性表
线性表(linear list)是n个具有相同特性的数据元素的有限序列。 线性表是一种在实际中广泛使用的数据结构,常见的线性表:顺序表、链表、栈、队列、字符串...
线性表在逻辑上是线性结构,也就说是连续的一条直线。但是在物理结构上并不一定是连续的,线性表在物理上存储时,通常以数组和链式结构的形式存储。
![](https://i-blog.csdnimg.cn/blog_migrate/69516a99a45799a779fd6a55140f7887.png)
2.顺序表
顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。
顺序表一般可以分为:
(1)静态顺序表:使用一定长度数组存储元素。
(2)动态顺序表:使用动态开辟内存的数组来存储元素。容量不够需要进行增容的操作。
3.链表
3.1 概念
概念:链表是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链
接次序实现的 。
3.2 分类
实际中链表的结构非常多样,以下情况组合起来就有8种链表结构:
(1)单向或者双向链表
![](https://i-blog.csdnimg.cn/blog_migrate/d1fe8e3946f0ad6d274931edd39b3b26.png)
(2)带哨兵位或者不带哨兵位
哨兵位指链表的第一个结点,开辟空间但不存放实际数据。主要方便尾插等操作。
(3)循环或者非循环
最常见的两种结构是单向不带哨兵位不循环链表和双向带哨兵位循环链表。
单向不带哨兵位不循环链表:
结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结
构,如哈希桶、图的邻接表等等。
双向带哨兵位循环链表:
结构最复杂,一般用在单独存储数据。实际中使用的链表数据结构,都是带头双向循环链表。虽然结构复杂,但是函数接口的实现非常方便,只需要实现任意位置插入和任意位置删除就可以在头删头插尾删尾插来复用函数。
4.顺序表和链表的区别
顺序表优点:
支持随机访问 O(1)。缓存利用率高。在数据的存储上,一定连续。尾插尾删比较方便。
缺点:
在任意位置插入和删除需要挪动数据,效率低O(N)。容量不够时需要扩容,而扩容的操作需要消耗性能(realloc异地扩容)。
链表优点:
任意位置插入或者修改元素,只需要修改指针指向,不需要挪动数据。链表没有容量的概念,不需要增容。
缺点:
不支持随机访问,效率慢O(N),需要遍历整个链表。数据存放不一定连续。缓存利用率低。