目录
- .顺序表
- .链表
- 比较
.顺序表
线性表的顺序存储结构,使用一段物理地址连续的存储单元以此存储数据单元的线性结构(从头开始连续存储)
- 静态顺序表:使用定长数组存储
- 动态顺序表:使用动态开辟的数组存储(常用)
// 顺序表的动态存储
typedef int SLDataType;
typedef struct SeqList
{
SLDataType* array; // 指向动态开辟的数组
size_t size ; // 有效数据个数
size_t capicity ; // 容量空间的大小
}SeqList;
实现同动态通讯录,其本质就是动态顺序表
.链表
链表是线性表的链式存储结构,是一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的 。
一个单链表
线性表相关功能通过接口函数实现
以单链表接口函数为例
// 打印单链表
void SListPrint(SLTNode* phead);
// 尾插
void SListPushBack(SLTNode** pphead, SLTDataType x);
// 头插
void SListPushFront(SLTNode** pphead, SLTDataType x);
// 尾删
void SListPopBack(SLTNode** pphead);
// 头删
void SListPopFront(SLTNode** pphead);
//创建新节点
SLTNode* BuyListNode(SLTDataType x);
//删除节点
void SListInsert(SLTNode** pphead, SLTNode* pos);
//pos位置后前插入
void SListErase(SLTNode** pphead, SLTNode* pos, SLTDataType x);
//销毁
void SListDestroy(SLTNode** pphead);
比较
顺序表
优点:
- 支持随机访问
- cpu高速缓存命中率更高
缺点:
- 头部及中部插入或删除,时间效率低(
O(N)
) - 增容有一定程度消耗,倍数扩容会造成空间浪费
链表
优点:
- 任意位置插入删除效率高,O(1)
- 按需申请空间,空间利用率较高
缺点:
- 不支持随机访问,不适用排序、二分等算法
- 每个节点需存储链接指针,有一定消耗
- cpu高速缓存命中率更低