大话数据结构笔记——第三章:线性表

线性表的定义

线性表(List):零个或多个数据元素的有限序列,直接前驱元素直接后继元素。在线性表中间的数据元素,有且只有一个直接前驱元素和直接后继元素。线性表元素的个数n(n>=0)定义为线性表的长度,当n=0时称为空表。在较复杂的线性表中,一个数据元素可以由若干个数据项组成。

线性表的抽象数据类型

ADT 线性表

DATA Operation
线性表的数据对象集合为{ a 1 a_1 a1, a 2 a_2 a2,……, a n a_n an},数据类型DataType。其中,除了第一个元素外,每个元素有且只有一个前驱元素,除了最后一个元素外,没有元素有且只有一个后继元素。数据元素之间的关系是一对一的关系 InitList(*L):初始话操作,建立一个空的线性表 ,ListEmpty(L),ClearList(*L),GetElem(L,i,*e)

end ADT
Tip:感觉像面向对象编程一样

线性表的顺序存储结构

指的是用一段地址连续的存储单元一次存储线性表的数据元素。所以可以用一维数组来实现顺序存储结构。顺序存储结构的三个属性:

  1. 存储空间的起始位置:数组data,它的存储位置就是存储空间的存储位置。
  2. 线性表的最大存储容量:数组长度MaxSize。
  3. 线性表的当前长度:length。

数组长度与线性表长度的区别:
数组长度一般不变,线性表长度会随着数据的插入和删除操作而产生变化,不过,在任意时刻,线性表的长度应该小于等于数组的长度。

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

获取元素操作

#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
typedef int Status;

Status GetElem(SqList L,int i,ElemType *e)
{
	if (L.length == 0 || i < 1 || i > L.length)
		return ERROR;
	*e = L.data[i-1];
	return OK;
	
}

插入操作

插入算法的思路:

  1. 如果插入位置不合理,抛出异常;
  2. 如果线性表长度大于等于数组的长度,则抛出异常或动态增加容量;
  3. 从最后一个元素开始向前遍历到第i个位置,分别将它们都向后移动一个位置;
  4. 将要插入元素填入位置i处;
  5. 表长加1。
/*初始条件:顺序线性表L已存在,1 <=i <=ListLength(L)*/
/*操作结果:在L中第i个位置之前插入新的数据元素e,表长+1*/

Status ListInsert(SqList *L, int i,ElemType e)
{
	int k;
	if (L->length==MAXSIZE) //线性表满
	{
		return ERROR;
	}
	if (i<1 || i> L->length+1) //不在表范围
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值