JAVA顺序表基础函数实现

该博客详细介绍了如何使用Java实现基础的顺序表操作,包括初始化、清空、判断是否为空、获取长度、获取指定位置元素、查找元素位置、插入元素和删除元素等方法。示例代码展示了每个操作的具体实现,可用于理解数据结构的基础操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

基础函数实现(JAVA)

  1. InitList(int max) 初始化顺序表
  2. ClearList() 清空顺序表
  3. ListEmpty() 顺序表判空
  4. ListLength()顺序表长度
  5. GetElem(int i) 返回第i个元素的值
  6. LocateElem(int value) 找到值为value的第1个元素的位置
  7. ListInsert(int i, int value) 在第i个位置插入值为value的元素
  8. ListDelete(int i) 删除第i个位置的元素
public class InitList {
	private int length;
	private int [] list;
	
	public InitList(int max)  //构造函数,初始化顺序表,参数为数组的长度
	{
		this.list = new int[max];  
		this.length = 0;       //初始化顺序表的长度为0
	}
	
	public void ClearList(){   //清空顺序表
	    this.length = 0;
	}
	
	public boolean ListEmpty()  //判断顺序表是否为空
	{
		if(this.length==0)
			return true;
		else
			return false;
	}
	
	public int ListLength()  //返回顺序表的长度
	{
		return this.length;
	}
	
	public int GetElem(int i)  //返回顺序表第i个元素的值
	{
		if(i<1||i>this.length)
			return -1;
		int t = this.list[i-1];
		
		return t;
	}
	
	public int LocateElem(int value) //找到顺序表中第一次出现值为value的元素,并返回为第i个元素
	{
		if(this.length==0)
			return -1;
		for(int i = 0; i < this.length; i++)
		{
			if(this.list[i]==value)
				return  i + 1;
		}
		return 0;
	}
	
	public int ListInsert(int i, int value)  //给顺序表第i个位置插入值为value的元素
	{
		if(this.length==this.list.length)
			return -2;
		if(i < 1||i > this.length+1)
			return -1;
		if(i<=this.length)
		{
			for(int k = this.length - 1; k > i; k--)
		    {
			    this.list[k+1] = this.list[k];
		    }
		}
		
		this.list[i-1] = value;
		this.length++;
		return 0;
	}
	
	public int ListDelete(int i) //删除顺序表中第i个元素
	{
		if(i<1||i>this.length)
			return -1;
		if(this.length==0)
			return -2;
		if(i<this.length)
		{
			for(int k = i; k >this.length; k++)
				this.list[k-1]=this.list[k];
		}
		this.length--;
		return 0;
	}
	
    public static void main(String []args) {  //主函数
        InitList list= new InitList(10);
		
		boolean empty = list.ListEmpty();
		int length = list.ListLength();
		int insert = list.ListInsert(1,10);
		System.out.println(list.ListLength());
		System.out.println(list.LocateElem(10));
		int delete = list.ListDelete(1);
		System.out.println(list.ListLength());
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值