数据结构(Java ArrayList模拟)本代码重在学习数据结构思路,代码完整性欠缺,请见谅

ArrayList的核心是以动态数组为存储结构。

class ArrayList<T>{
 private int capability ;
 private static final int defaultCapability = 8;
 private int size = 0;
 private Object[] array = null;
 public ArrayList(final int n){
  this.capability = n;
     this.array = new Object[capability];
 }
 public ArrayList(){
    this.capability = defaultCapability;
    this.array = new Object[capability];
 }
 //添加数据
 public void add(T data){
  Object obj = (Object)data;
  resizeArray();
  array[size] = data;
  size++;
  
 }
 public int size(){
  return size;
 }
 public T get(int index){
  if( index < 0 ||  index >= size)
   return null;
  return (T)array[index];
 }
 public T remove(int index){
  T t = get(index);
  if( t != null ){
   
   for(int i = index; i < size-1; i++){
    array[i] = array[i+1];
   }
   size --;
  }
  return t;
 }
 //当数据量为总容量的75%时重新设置数组的大小
 private void resizeArray(){
  if(size*4 > capability*3 ){
   capability = capability *2;
   Object[] result = new Object[capability];
   System.arraycopy(array, 0, result, 0, size);
   array = result;
  }
 }
}
public class ArrayListTest {
 public static void main(String[] args) {
  ArrayList<String> arrays = new ArrayList<String>();
  arrays.add("123");
  arrays.add("124");
  arrays.add("125");
  arrays.remove(1);
  //System.out.println(arrays.get(4));
  for(int i =0 ;i< arrays.size(); i++)
   System.out.println(arrays.get(i));
 }

}

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值