1.1用数组实现列表-MyArrayList

线性表(列表)的接口定义

import java.util.Iterator;
public interface MyList<T> extends Iterator<T> {
  void add(T element);//新增一个元素
  void delete(T element);//删除相同元素
  void delete(int index);//根据索引删除元素
  void update(int index, T newElement);//索引位置元素替换为新元素
  boolean contains(T target);//当前列表是否包含target这个元素
  T at(int index);//返回指定索引处的元素
  int indexOf(T element);//查找element的索引,如果没有返回-1
}

接下来用顺序存储的方式实现列表

使用implements,接口只会定义功能,要围绕功能来设计数据

//只是框架,暂时没有具体作用
public class MyArrayList implements MyList{	
	@Override
	public boolean hasNext() {
		return false;
	}
	@Override
	public Object next() {
		return null;
	}
	@Override
	public void add(Object element) {
	}
	@Override
	public void delete(Object element) {		
	}
	@Override
	public void delete(int index) {
	}
	@Override
	public void update(int index, Object newElement) {
	}
	@Override
	public boolean contains(Object target) {
		return false;
	}
	@Override
	public Object at(int index) {
		return null;
	}
	@Override
	public int indexOf(Object element) {
		return 0;
	}
}

则列表要有自己的一片空间,用数组的方式开辟这部分空间

private Object[] elements;//elements 真正存储元素的底层结构
private int size;//列表中定义的元素个数
private int capacity;//容量(最多可以存储的)
//size和capacity是辅助element的

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值