【数据结构】线性表——静态链表

普通的单链表的各个结点在内存中的分布是随机的,星罗棋布的。

而静态链表是通过用一个数组来表示,在内存中有一整片连续的空间,各个结点集中安置。

用代码定义一个静态链表

静态链表的结点包含一个存储的数据元素,以及一个int型用于存放下一个数组的下标。

#define MaxSize 10     // 静态链表的最大长度
struct Node
{
    ElemType data;
    int next;         // 下一个元素的数组下标
};

void textSLinkList(){
    struct Node a[MaxSize];  // 数组a作为静态链表
    //......
}

 另一种写法:

typedef struct 
{
    ElemType data;
    int next;         // 下一个元素的数组下标
}SLinkList[MaxSize];

void textSLinkList(){
    SLinkList a;
    //......
}

这两种写法是等价的。

第一种:定义一个struct Node类型,长度为MaxSize的名为a的数组,用这个数组表示链表。

第二种:在定义结构体的时候就已经定义了一个长度为MaxSize的Node型数组,后续代码中就可以直接使用SLinkList定义了。

基本操作简述

  • 初始化静态数组:将a[0]的next设为-1,将其他结点的next设为一个特殊值用来表示结点空闲,如-2.
  • 查找: 从头结点出发挨个往后遍历结点
  • 插入位序为i的结点:
    • ①找到一个空的结点,存入数据元素
    • ②从头结点出发找到位序为i-1的结点
    • ③修改新结点的 next
    • ④修改 i-1 号结点的 next
  • 删除某个结点:
    • ①从头结点出发找到前驱结点
    • ②修改前驱结点的游标
    • ③被删除结点 next 设为 -2

总结

静态链表:  用数组的方式实现的链表

优点:  增、删操作不需要大量移动元素

缺点:  不能随机存取,只能从头结点开始依次往后查找;  容量固定不可变

适用场景:

①不支持指针的低级语言;

②数据元素数量固定不变的场景(如操作系统的文件分配表FAT)

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值