在之前的绪论部分中我们了解到线性表是一种逻辑结构,即一串数据,那么在计算机实现线性表时有两种基本方式:数组和链表。
今天就来说一下用数组,即顺序表的方式如何实现线性表。
- 分析
线性表其实就是一串数据,用数组来实现线性表,即把线性表对应到数组上寻找相应的值。
数组:由元素和下标构成。
元素:Object类型,来存储线性表中的元素
下标:用数组长度n来表示,来表示线性表的长度。 - 由此可得顺序表类的定义为:
public class SeqList<T> {
protected Object[] element;
protected int n;
基本方法有:
构造一定长度的空顺序表
public SeqList(int length) {
this.element=new Object[length];
this.n=0;
}
用values[]数组构造顺序表
public SeqList(T[] values) {
this(values.length);
for(int i=0;i<values.length;i++)
this.element[i]=values[i];
this.n=element.length;
}
插入数据
public int insert(int i,T x) {
if(x==null)
System.out.println("x is null");
if(i<0) i=0;
if(i>this.n) i=this.n;
Object[] source=this.element;
if(this.n==element.length)
{
this.element=new Object[source.length*2];
for(int j=0;j<i;j++)
this.element[j]=source[j];
}
for(int j=this.n-1;j>=i;j--)
this.element[j+1]=source[j];
this.element[i]=x;
this.n++;
return i;
}
删除元素
public T remove(T key) {
if(this.contains(key)==true) {//contains()方法是判断是否包含KEY元素,类型为布尔类型
return this.remove(this.search(key));//使用已经编写的remove方法,根据下标删除元素,大家尝试自己编写此方法
}
else {
System.out.println("不存在该元素");
return null;}
}
顺序表还有很多的方法,遍历顺序表是最基础的方法。
可以用顺序表实现数组的并交集,在此注意顺序表的特点:静态性好:查找元素的时间复杂度为O(1),但是动态性不好:每次插入或删除元素都要遍历顺序表,时间复杂度为O(n)。
所以当涉及到需要经常查找元素,不经常进行元素的删除和增加时使用顺序表会效率更高,当涉及频繁地删除和增加元素时应使用链表来实现线性表,再次强调线性表是一种逻辑结构,关于链表的使用和基本方法在下回讲。