基础数据结构和算法2:顺序表

1、线性结构

数据结构中最常用最简单的结构是线性结构。
线性结构,又称线性表。逻辑结构上数据元素之间存在一个对一个的相邻关系。线性结构是n个数据元素的有序(次序)集合,它有下列几个特征:
1.集合中必存在唯一的一个"第一个元素";
2.集合中必存在唯一的一个"最后的元素";
3.除最后元素之外,其它数据元素均有唯一的"后继";
4.除第一元素之外,其它数据元素均有唯一的"前驱"。

2、顺序表是什么

顺序表是用一组地址连续的存储单元依次存储线性表中的各个元素,使线性表中在逻辑结构上相邻的数据元素存储在相邻的物理存储单元中。
数组的缺点:大小(元素个数)不能改变,不能适用于元素个数变化的情况。
数组可以看作无法改变大小的顺序表。

3、顺序表怎么用?

顺序表通过一个结构体和结构体对应的接口使用

4、顺序表怎么实现?

4.1 定义结构

#include <stdio.h>

typedef int Sq;

typedef struct{
    Sq  *num;
    int size;
}List;

定义一个存储单元类型SeqType是为了使顺序表适和更多数据类型,使用的时候修改SeqType类型即可。

4.2 定义操作

(1)初始化顺序表

为什么要初始化?因为局部变量默认初始化为随机值
怎么初始化?把结构体变量成员赋值为合法的初始值

bool sqlist_init(SqList* plist);

(2)添加元素

int sqlist_append(SqList* plist,SeqType value);
int sqlist_prepend(SqList* plist,SeqType value);

(3)获取元素

SeqType sqlist_get(SqList* plist,int index);

(4)获取元素个数

int sqlist_size(SqList* plist);

为什么不直接从结构体获取?

(5)插入元素

int sqlist_insert(SqList* plist,int index,SeqType value);

(6)删除元素

SeqType sqlist_remove(SqList* plist,int index);

(7)销毁顺序表

bool sqlist_destroy(SqList* plist);

5、优化

5.1 容量

每次增加一个元素,都要重复释放申请内存。可以预先申请一部分备用。

int capacity;   //当前分配的存储容量

每次预先申请多少?

5.2 创建

用户使用SeqType初始化,可以把结构体定义和初始化合二为一

SeqType sqlist_create(int size);

5.3 随即访问元素

获取元素sqlist_get(),只能获取到顺序表中的元素的副本,如果需要改变顺序表中的元素,可以提供如下函数。

SeqType* sqlist_at(SqList* plist,int index);

5.4 遍历

提供一个对顺序表的整体操作的接口。

typedef void (*SqList_Traversal)(const SeqType* value);
void sqlist_traverse(SqList* plist,SqList_Traversal fp);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值