数据结构第三章:线性表(1)

                                                                     线性表的定义

 

1、 定义:零个多个数据元素有限序列。(元素要是相同的数据类型

 

2、 用数学语言:若将线性表记为(A1,A2,.....Ai-1,Ai,Ai+1......An),则表中Ai-1领先于Ai,Ai领先于Ai+1,称Ai-1是Ai的直接前驱元素,Ai+1是Ai的直接后继元素。当i=1,2......,n-1时,Ai有且仅有一个直接后继,当i=2,3....,n时,Ai有且仅有一个直接前驱。

 

3、线性表元素的个数n(n>=0)定义为线性表的长度,当n=0时,称为空表

 

4、非空链表中的每一个数据都有一个确定的位置。Ai是第 i 个数据元素,称 i数据元素Ai在线性表中的位序

 

5、在较复杂的线性表中,一个数据元素可以由若干个数据项组成。

 

 

                                                             线性表的抽象数据类型

 

ADT  线性表(List)

Data

             线性表的数据对象集合为{a1,a2,a3.......an},每个元素的类型均为DataType。其中,除第一个元素a1外,每一个元素有且只有一个直接前驱元素,除了最后一个元素an外,每一个元素有且只有一个直接后继元素。数据元素之间的关系是一对一的关系。

Operation

          Initlist( *L ) :  初始化操作,建立一个空的线性表L。

 

          ListEmpty( L ) :  若线性表为空,返回true,否则返回false。

 

          Clearlist( *L ) :  将线性表清空。

 

          GetElem( L , i , *e) :  将线性表L中的第i个位置元素返回给e。

 

          LocateElem( L , e) :  在线性表L中查找与给定值e相等的元素。如果查找成功,返回该元素在表中序号表示成功;否则返回0表示失败。

 

          ListInsert( *L , i , e) :  在线性表L中的第i个元素插入新元素e。

 

          ListDelete(*L , i , *e) :  删除线性表L中第i个位置元素,并用e返回其值。

 

          ListLength( L ) :  返回线性表L的元素个数。

endADT

 

 

                                                                 线性表的顺序存储结构

 

1、顺序存储定义:指的是用一段地址连续的存储单元依次存储线性表的数据元素。

 

2、顺序存储方式:用一维数组来实现顺序存储结构

 

3、顺序存储的结构代码:

#define MAXSIZE 20         //存储空间初始分配量

typedef int ElmeType;      //ElemType类型根据实际情况而定,这里假设为int *

tppedef struct

{

   ElemType data[MAXSIZE];//数组存储数据元素,最大值为MAXSIZE

   int length;                          //线性表当前长度。

}

 

顺序存储结构需要三个属性:

(1)存储空间的起始位置:数组data,它的存储位置就是存储空间的存储位置。

(2)线性表的最大存储容量:数组长度MAXSIZE。

(3)线性表当前长度:length。

 

4、在任意时刻,线性表的长度应该小于等于数组长度。

 

5、地址计算方法

    (1)存储器中的每个存储单元都有自己的编号,这个编号称为地址。

    (2)因为是顺序存储,所以如果第一个位置确定后,后面的位置都可以计算的。

    (3)由于每个数据元素,不管它是整型、实型还是字符型,它都是需要占用一定的存储单元空间的。假设占用的是c个存储单元,那么线性表中第i+1个数据元素的存储位置和第i个数据元素的存储位置满足下列关系。(LOC表示获得存储位置的函数)

LOC(a i+1)=LOC(a i)+c

LOC(ai)=LOC(a1)+(i-1)*c

 

       这样,就可以算出任意位置的地址,线性表的每一个位置的存入和取出数据,对于计算机来说,都是相同的时间,也就是是一个常数。则,它的存取性能为O(1),我们通常把具有这一特点的存储结构称为随机存储结构

 

 

                                                                 顺序存储结构的插入与删除

插入操作:

              在线性表 L 中的第 i 个位置插入新元素e,位置 i 以后的元素(包括 i )都向后挪一个位置,再让 e 插入第 i 个位置,表长加 1。

 

删除操作:

              在线性表 L 中找到需要删除的元素的位置 i ,取出删除元素,并将 i 位置以后的元素都向前挪一个位置,表长减 1。

 

  线性表的顺序存储结构,在存、读数据时,时间复杂度为O(1),而插入或删除数据时,时间复杂度为O(n)。

 

线性表的顺序存储结构的优缺点:

优点:

    1、无须为表示表中元素之间的逻辑关系而增加额外的存储空间。

    2、可以快速的存取表中任一位置的元素。

 

缺点:

    1、插入和删除操作需要移动大量元素。

    2、当线性表长度变化较大时,难以确定存储空间的容量。

    3、造成存储空间的“碎片”。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值