|
EDA365欢迎您登录!
您需要 登录 才可以下载或查看,没有帐号?注册
x
线性表的顺序表示指的是用一组地址连续的存储单元一次存储线性表的数据元素。
( b# A) M2 f4 Z5 \6 ~& V7 i假设线性表的每个元素需占用l个存储单元,并以所占的第一个单元的存储地址作为数据元素的存储位置LOC(ai)之间满足下列关系:
, g: V, p% q( Q8 s p3 ?7 |$ wLOC(ai)= LOC(ai)+l' r d) l9 ~4 }$ f* C& O; Y0 Y
一般来说,线性表的第i个数据元素ai的存储位置为/ g E" C% |, @- `
LOC(ai)= LOC(ai)+(i-1)×l1 H/ K: j5 c% _; E+ T' Z; _9 ^
式中LOC(ai)是线性表的第一个数据元素ai的存储位置,通常称作线性表的其实位置或基地址。3 n1 z* X" h( r8 }: P
线性表的这种机内表示称做线性表的顺序存储机构或顺序映像,通常,称这种存储结构的线性表为顺序表。它的特点是,为表中相邻的元素ai和ai+1赋以相邻的存储位置LOC(ai)和LOC(ai+1)。换句话说,每一个数据元素的存储位置都和线性表的起始位置相差一个和数据元素在线性表中的位序成正比的常数。由此,只要确定了存储线性表的起始位置,线性表中任一数据元素都可随机存取,所以线性表的顺序存储结构是一种随机存取的存储结构。$ X, j* N& t, L/ {0 r- j
由于高级程序设计语言中的数组类型也有随机存取的特性,因此,通常都用数组来描述数据结构中的顺序存储结构。在此,由于线性表的长度可变,且所需最大存储空间随问题不同而不同,则在C语言中可用动态分配的一维数组,如下描述。" v4 Z' Z2 |, X! |" n3 l2 K0 ~2 [
#define LIST_INIT_SIZE 100 //线性表存储空间的初始分配量- b/ X" Y; P! k2 c* v! h
#define LISTINCREMENT 10 //线性表存储空间的分配增量
$ p/ `0 P% K3 |6 r& @typedef struct{7 H) I) i" O, \, v1 T' ~5 a, G# `
ElemType *elem; //存储空间基址
1 ^! {' w C+ z4 |# h6 a int length //当前长度/ s2 E6 C# j( }+ X
int listsize; //当前分配的存储容量# {: Q7 f5 Y7 T" \9 Q" d! e
}SqList;
( w3 L2 W. L+ r; o2 g) p* M0 k在上述定义中,数组指针elem指示线性表的基地址,lenth指示线性表的当前长度。顺序表的初始化操作就是为顺序表分配一个预定义大小的数组空间,并将线性表的当前长度设为“0”。Listsize指示顺序表当前分配的存储空间大小,一旦因插入元素而空间不足时,可进行再分配,即为顺序表增加一个大小为存储LISTINCREMENT个数据元素的空间。
; p% Y. I, y! W& y0 T S0 xStatus InitList——Sq(SqList 7L){
# p9 m8 N$ @3 b+ l//构造一个空的线性表L。/ Q2 m- x& `5 |" `( q
L.elem=(ElemType *)malloc(LIST_INIT_SIZE *sizeof(ElemType));- i% x) z! z, B5 ?. [3 e5 L
If(! L.elem)exit(OVERFLOW); //存储分配失败
2 w- V1 D) r& t4 c# p. aL.length=0; //空表长度为0% @3 i: }4 l1 k h' N% c0 o0 g
L.listsize= LIST_INIT_SIZE; //初始存储容量
7 {" x# e& y' K5 A+ m; Q jreturn OK;3 f1 B, f2 l4 ~: h- f9 |. w' b. }0 G
}//InitList_Sq |
|