顺序表的描述(java语言描述)

本文介绍了顺序表的概念,它是通过一组地址连续的存储单元存储线性表元素的结构。顺序表具有随机访问的优点,但插入和删除操作可能导致数据大量移动。文章详细描述了如何使用Java实现顺序表的接口,并探讨了插入和删除操作的实现,包括插入时检查空间和位置有效性,以及删除时的数据左移策略。
摘要由CSDN通过智能技术生成

顺序表,就是顺序存储的线性表,顺序存储是用一组地址连续的存储单元依次存放线性表中各个元素的存储结构,具有便于随机存取的优点,缺点是插入删除操作比较麻烦,在进行插入删除的同时,会引起大量数据的移动,而且需要预先分配空间,会造成空间的浪费。下面先用一个接口表明顺序表需要实现的基本操作。

public interface IList {
 public void clear();//将表中的元素置空
 public boolean isEmpty();//判断是否为空表
 public int length();//求线性表元素的个数
 public Object get(int i) throws Exception;//返回下标为i的元素
 public void insert(int i,Object x) throws Exception;//在i位置插入元素x
 public void remove(int i) throws Exception;//删除i位置的元素
 public int indexOf(Object x) throws Exception;//求数据为x的下标
 public void display();//输出数据元素
}

接下来对顺序表类进行描述,实现IList接口

public class SqList implements IList {
 private Object[] listElem;//线性表存储空间
 private int curLen;//线性表当前长度
 public SqList(int maxSize) {
  curLen = 0;
  listElem = new Object[maxSize];
 }
 //置空
 public void clear() {
  curLen = 0;
 }
 //判断线性表数据元素是否为空,是返回true
 public boolean isEmpty() {
  return curLen =
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值