3_线性表_顺序存储

线性表之顺序存储结构

线性表(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源码链接
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值