Java线性表[增删查]

package 数据结构与算法;

import java.util.Arrays;

public class 面向对象的数组 {
	
	//用于存储数据的数组
	private int[] elements;
	
	public 面向对象的数组(){
		elements = new int[0];
	}
	
	//获取数组长度的方法
	public int size() {
		return elements.length;
	}
	
	//往数组的末尾添加一个元素
	public void add(int element) {
		int [] newArr = new int[elements.length +1];
		
		//把原数组中的元素复制到新数组中
		for(int i=0 ; i<elements.length ; i++) {
			newArr[i] = elements[i];
		}
		
		//把添加的元素放入新数组中
		newArr[elements.length] = element;
		
		//用新数组更换新数组
		elements = newArr;
	}
	
	//打印所有元素到控制台
	public void show(){
		System.out.println(Arrays.toString(elements));
	}
	
	//----------------------//
	//删除数组中的元素
	public void delete(int index) {
		//判断删除的位置是否下标越界
		if(index < 0 || index > elements.length-1) {
			throw new RuntimeException("下标越界"); 
		}
		//创建一个新的数组,长度为原数组的长度-1
		int[] newArr = new int[elements.length-1];
		//复制原有数组数据到新数组
		for(int i = 0 ; i<newArr.length ; i++) {
			//想要删除的元素前面的元素
				if(i < index) {
					newArr[i] = elements[i];
				}else {//想要删除元素后面的元素
					newArr[i] = elements[i+1];
				}
		}
		//新数组替换旧数组
		elements = newArr;
	}
	
	//获取某个元素
	public int get(int index) {
		if(index>elements.length-1 || index<0) {
			throw new RuntimeException("下标越界");
		}
		return elements[index];
	}
	
	//插入一个元素到指定位置
	public void insert(int index,int element) {
		//创建一个比原数组大的数组
		int[] newArr = new int[elements.length+1];
		//将原数组中的元素访日新数组中
		for(int i=0 ; i<elements.length ; i++) {
			//目标位置之前的元素
			if(i < index) {
				newArr[i] = elements[i];
			}else {
				newArr[i+1] = elements[i];
			}
		}
		//插入新的元素
		newArr[index] = element;
		
		//新数组替换旧数组
		elements = newArr;
	}
	
	//替换指定位置的元素
	public void set(int index,int element) {
		if(index>elements.length-1 || index<0) {
			throw new RuntimeException("下标越界");
		}
			elements[index] = element;
	}
}


测试类

package 数据结构与算法;

public class 面向对象数组的测试类 {
	public static void main(String[] args) {
		面向对象的数组 ma = new 面向对象的数组();
		System.out.println(ma.size());
		
		//往可变数组中添加一个元素
		ma.add(11);
		ma.add(22);
		ma.add(33);
		ma.add(44);
		ma.add(55);
		ma.add(66);
		ma.add(77);
		ma.add(88);
		System.out.println(ma.size());
		ma.show();
		
		//删除某个元素
	//	ma.delete(2);
	//	ma.show();
		
		//取出数组中指定位置的元素
		//System.out.println(ma.get(0));
		
		//插入一个元素到指定位置
		ma.insert(1, 10);
		ma.insert(0, 0);
		ma.insert(8, 1010);
		ma.show();
		
		//替换数组中的元素
		ma.set(1,88);
		ma.show();
	}
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值