线性表之顺序存储结构
线性表(List)
- 定义:零个或多个数据元素的有限序列
- 数学语言定义:a1,a2…ai…an
- ai有且只有一个前继元素 a(i-1)和 一个后继元素 a(i+1)
顺序存储结构
- 一段连续的存储单元一次存储线性表的数据元素(如,数组)
- 所需属性:
- 一个起始位置
- 最大存储容量
- 当前的长度
代码实现
public class SqList<T> { private static int MAXSIZE = 20; private T[] data; private int length = 0; }
基本操作
添加元素
- 判断数组是否还有空间
- 如果还有空间,就在末尾添加元素
代码实现
public boolean add(T e) { if(this.length == MAXSIZE) throw new IndexOutOfBoundsException("数组已经达到最大存储空间"); this.data[this.length++] = e; return true; }
获取元素
- 判断下标是否符合要求
- 如果符合要求,就返回该下标的值
代码实现
public T getElem(int i){ if(this.length == 0 || i < 0 || i >= this.length){ throw new IndexOutOfBoundsException("下标越界。下标: " + i +", 当前大小: " + this.length); } return data[i]; }
插入元素
- 判断数组是否还有空间,下标是否符合要求
- 下标之后的元素往后移动,然后修改该下标元素的值
代码实现
public boolean insert(int i, T e) { int k; if (this.length == MAXSIZE) throw new IndexOutOfBoundsException("数组已经达到最大存储空间"); if (i < 0 || i > this.length) throw new IndexOutOfBoundsException("下标越界。下标: " + i +", 当前数组大小: " + this.length); if (i < this.length) { for (k = this.length; k >= i; k--) this.data[k] = this.data[k-1]; } this.data[i] = e; this.length ++; return true; }
删除元素
- 与上类似
说明
- 此文中的代码只是简单实现,详细参考 java.util.ArrayList
- 这个实现是非线性安全的,可参考 ArrayList 对 modCount 变量的处理
- ArrayList 在移动数组位置时,使用了 native 方法
- github源码链接