java 数组栈_java——数组栈 ArrayStack

packageDate_pacage;public class Array{//叫它静态数组//private int[] data;

privateE[] data;private intsize;//构造函数

public Array(intcapacity) {

data= (E[])newObject[capacity];

size= 0;

}//无参数的构造函数,默认数组的容量为10

publicArray() {this(10);

}public intgetSize() {returnsize;

}public booleanisEmpty() {return size == 0;

}public intgetCapacity() {returndata.length;

}//O(1)

public voidaddLast(E e) {

add(size, e);

}//O(n)

public voidaddFirst(E e) {

add(0, e);

}//O(n/2) = O(n)

public void add(intindex, E e) {if(size>=data.length)

resize(2 *data.length);if(index<0 || index>size)throw new IllegalArgumentException("Add failed.index is error.");for(int i=size-1;i>=index;i--) {

data[i+1] =data[i];

}

data[index]=e;

size++;

}

@OverridepublicString toString() {

StringBuilder res= newStringBuilder();

res.append(String.format("Array: size = %d, capacity = %d\n", size, data.length));

res.append("[");for(int i = 0 ; i

res.append(data[i]);if(i != size - 1)

res.append(", ");

}

res.append("]");returnres.toString();

}public E get(intindex) {if(index < 0 || index >=size)throw new IllegalArgumentException("Get failed. Index is illegal");returndata[index];

}publicE getFirst() {return get(size - 1);

}publicE getLast() {return get(0);

}void set(intindex, E e) {if(index < 0 || index >=size)throw new IllegalArgumentException("Get failed. Index is illegal");

data[index]=e;

}public booleancontains(E e) {for(int i = 0; i < size; i++) {if(data[i].equals(e))return true;

}return false;

}public intfind(E e) {for(int i = 0; i < size; i++) {if(data[i].equals(e))returni;

}return -1;

}public E remove(intindex) {if(index < 0 || index >=size)throw new IllegalArgumentException("Get failed. Index is illegal");

E res=data[index];for(int i = index; i

data[i]= data[i+1];

}

size--;//释放空间,也可以不写//loitering objects != memory leak

data[size] = null;if(size == data.length / 4 && data.length / 2 != 0)

resize(data.length/ 2);returnres;

}publicE removeFirst() {return remove(0);

}publicE removeLast() {return remove(size-1);

}//只删除了一个e,并不能保证删除了全部e

public voidremoveElement(E e) {int index =find(e);if(index != -1)

remove(index);

}private void resize(intnewCapacity) {

E[] newData= (E[]) newObject[newCapacity];for(int i=0; i < size; i++) {

newData[i]=data[i];

}

data=newData;

}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值