《数据结构(java版)》学习笔记(二)——线性表的实现(上):顺序表实现线性表

在之前的绪论部分中我们了解到线性表是一种逻辑结构,即一串数据,那么在计算机实现线性表时有两种基本方式:数组链表
今天就来说一下用数组,即顺序表的方式如何实现线性表。

  • 分析
    线性表其实就是一串数据,用数组来实现线性表,即把线性表对应到数组上寻找相应的值。
    数组:由元素下标构成。
    元素: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)。
所以当涉及到需要经常查找元素,不经常进行元素的删除和增加时使用顺序表会效率更高,当涉及频繁地删除和增加元素时应使用链表来实现线性表,再次强调线性表是一种逻辑结构,关于链表的使用和基本方法在下回讲。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值