数据结构之线性表

1、定义

线性表(List):零个或多个数据元素的有限序列。

线性表的抽象数据类型定义如下:

ADT 线性表(List)

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


Operation:(基本的操作即实现增删改查的定义函数功能)
				InitList()   :初始化操作,建立一个空的线性表。
				ListEmpty();  //判断线性表是否为空
				ClearList()  ;//将线性表清空
				GetElement(i);//获取索引为i出的元素
				ListInsert(int index,e)  //在索引为index前插入元素 e
				ListDelete(int index) //删除线性表第index位置元素
				listLength()   //返回线性表L的元素的个数

2、线性表的顺序存储结构

2.1顺序线性表的定义

线性表的顺序存储结构:指的是用一段 地址连续 的 存储单元依次 存储线性表 的数据元素。
ps:关键是地址连续,这很重要。
线性表的顺序存储结构,说白了,就是在内存中找一块连续的地方存储一组数据。
**既然线性表的每个数据元素的类型都相同,所以可以用 一维数组 来实现顺序存储结构,即把 第一个数据元素存到数组下标为0的位置中,接着把线性表 相邻的元素存储在数组中相邻的位置。 **

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

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

因为底层是数组这里就牵扯到 顺序线性表的容量问题了,合理的数据结构 应该 在 数组的大小,数组的自动增容上加以考虑(Java ArrayList源码中做的就比较好,可以参考)。

2.2顺序线性表的操作

(1) 获得元素操作
对于现行表的顺序存储结构,如果 要实现 GetElem操作,即将线性表L中的第i个位置 元素值返回。
在这里插入图片描述

//获取索引为i的元素
		@SuppressWarnings("unchecked")
		public E get(int i) {
			rangecheck(i);
			return (E)elemenData[i];
		}

(2)插入操作
在线性表的第i个位置插入 新元素 e.
插入算法的步骤:

  • 如果插入的位置不合理抛出异常
  • 如果线性表长度大于数组长度,则抛出异常或动态增加容量
  • 腾位置(从最后一个元素 开始向前 遍历到第i个位置,分别将他们后移一个位置)
  • 将要插入元素填入位置i处。
  • 表长+1.

在这里插入图片描述

 //在线性表L中的第i个位置插入新元素e
		public void insert(int index,E element) {
			rangecheck(index); //越界检查
			//可能还需要进行扩容
			System.arraycopy(elemenData, index, elemenData, index+1, size-index);
			elemenData[index] = element;
			size++;
		}

(3)删除操作
删除算法的思路:

  • 如果删除位置不合理,抛出异常
  • 取出删除元素
  • 从删除元素位置开始遍历到最后一个元素位置,分别将它们都向前 移动 一个位置
  • 表长-1

在这里插入图片描述

	//删除线性表L中第i个元素
		public void remove(int index) {
			rangecheck(index);
			System.arraycopy(elemenData, index+1, elemenData, index, size-index);
			elemenData[size--]= null;
		}

优点:无需为表示表中元素之间的逻辑关系而增加额外的存储空间;可以快速的存取表中任一位置的元素
缺点:插入和删除操作需要移动大量元素;当线性表长度变化较大时,难以确定存储空间的容量;造成存储空间的碎片。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值