顺序表(Note3)

顺序表

定义:线性表的顺序存储就是顺序表。

线性表的顺序存储:一组地址连续存放的存储单元, 依次存放线性表中的元素,使得它们在逻辑上相邻也在物理地址上相邻。

所以,在顺序表中,逻辑顺序与物理顺序是相同的。

这样说吧,线性结构下的顺序存储。

1.1 在语言中以什么方式实现顺序表呢?

数组。但是数组可以是多维的,而顺序表只能是一维的。

在顺序表中,只要知道一个元素的内存地址,那么就能计算出它左右元素乃至所有元素的内存地址。

以下是一个数组实现的顺序表:

在这里插入图片描述

maxsize 是数组最后一个存储单元。sizeof()函数用来计算元素类型分配的空间大小。

所以只有知道其中一个元素的位置与大小,就能计算出所有元素的位置。

1.2 数组静态分配

以下是c语言中的书写方式:

#define MaxSize=50
typeof struct{
    ElemType data[MaxSize];
    int length;
}SqList;

maxsize, 数组大小=50,即data[50],用来存储顺序表元素;length是顺序表长度。

1.3 数组动态分配

#define MaxSize=50
typeof struct{
    ElemType *data;
    int length;
}SqList;

数组大小未知。

根据顺序表的特性可知,如果知道第一个元素的地址,那么其余元素的地址也就能求得。

所以,这就为动态分配提供了条件。

我们只需要声明一个指针即可(指针就是用来存储某个存储单元地址的东西)

也就是说,有了这个指针就有了第一个元素的地址,那么其余元素的地址也可以计算出来,那么顺序表就算是成立了。

但是,也仅仅只是有了一个指针,而没有元素。没有元素就没有存储空间。

那么当第一个元素存到指针中时,内存空间怎么分配给这个元素呢?

在C语言与C++语言中:

C  :  L.data = (Elemtype*)malloc(sizeof(ElemType)*InitSize);

C++ : L.data = new ElemType[InitSize];

L是SqList的一个变量,data是我们声明的指针。

总结:
在静态分配中,当存放元素超过50时顺序表出错。

在动态分配中,分配空间会随着元素的增多而继续向内存申请更大的空间。从而使得旧空间元素与新增元素有家可归。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值