【数据结构】顺序表和链表

.顺序表

线性表的顺序存储结构,使用一段物理地址连续的存储单元以此存储数据单元的线性结构(从头开始连续存储

  • 静态顺序表:使用定长数组存储
  • 动态顺序表:使用动态开辟的数组存储(常用)

在这里插入图片描述

// 顺序表的动态存储
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高速缓存命中率更低
  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值