数据结构--静态链表

数据结构–静态链表

单链表 VS 静态链表

单链表:各个结点在内存中星罗棋布、散落天涯。

静态链表:分配一整片连续的内存空间,各个结点集中安置。

代码定义

代码一:

#define MaxSize 10 //静态链表的最大长度
typedef struct //静态链表结构类型的定义
{
    ElemType data; //存储数据元素
    int next; //一个元素的数组下标
} SLinkList[MaxSize];

代码二:

#define MaxSize 10
struct Node
{
    ElemType data;
    int next;
};
typedef struct Node SLinkList[MaxSize];

代码一与代码二相互等价

查找:
从头结点出发挨个往后遍历结点
时间复杂度 O(n)

插入位序为i的结点:
①找到一个空的结点,存入数据元素
②从头结点出发找到位序为 i − 1 i-1 i1 的结点
③修改新结点的 next
④修改 i − 1 i-1 i1 号结点的 next

删除某个结点:
①从头结点出发找到前驱结点
②修改前驱结点的游标
③被删除结点next设为一个约定值

知识点回顾与重要考点

静态链表:用数组的方式实现的链表
优点:增、删操作不需要大量移动元素
缺点:不能随机存取,只能从头结点开始依次往后查找: 容量固定不可变 \color{red}容量固定不可变 容量固定不可变

适用场景:
①不支持指针的低级语言;
②数据元素数量固定不变的场景(如操作系统的文件分配表FAT)

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Joanh_Lan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值