自定义实现简易版ArrayList

简介: 自定义实现简易版ArrayList

1.了解什么是顺序表

顺序表是用一段物理地址连续的存储单元依次存储数据元素的线性结构,一般情况下采用数组存储。在数组上完成数据的增删查改。

2.实现哪些功能

对于一个顺序表来说

我们做的最多的也就是增删查改

则实现以下接口:

public interface IList {
    //新增元素,默认在数组最后新增
    public void add(int data);
    // 在 pos 位置新增元素
    public void add(int pos, int data);
    // 判定是否包含某个元素
    public boolean contains(int toFind) ;
    // 查找某个元素对应的位置
    public int indexOf(int toFind);
    // 获取 pos 位置的元素
    public int get(int pos);
    // 给 pos 位置的元素设为 value  更新
    public void set(int pos, int value);
    //删除第一次出现的关键字key
    public void remove(int toRemove) ;
    // 获取顺序表长度
    public int size();
    // 清空顺序表
    public void clear() ;
    // 打印顺序表,注意:该方法并不是顺序表中的方法,为了方便看测试结果给出的
    public void display();
  //判断是否已满
    boolean isFull();
  //判断是否为空
    public boolean isEmpty();
}

3.初始化ArrayList

usedSize为使用的长度

DEFAULT_SIZE = 10为默认顺序表的容量

两个构造方法

无参构造:顺序表默认大小为10;

有参构造:自定义顺序表大小;

public class MyList implements IList{
    public int[] elem ;
    public int usedSize;//0
    //顺序表的 默认大小
    public static final int DEFAULT_SIZE = 10;
    public MyList(){
        this.elem = new int[DEFAULT_SIZE];
    }
    public MyList(int capacity){
        this.elem = new int[capacity];
    }
 }

4.实现功能接口

遍历顺序表

public void display(){
        for (int i = 0; i < usedSize; i++) {
            System.out.print(elem[i]+" ");
        }
        System.out.println();
    }

判断顺序表是否已满

public boolean isFull(){
        return usedSize == elem.length;
     }

添加元素

checkCapacity()判断顺序表是否已满,如果已经满了则进行扩容

扩容为原来顺序表的两倍

 private void checkCapacity(){
        if(isFull()){
            elem = Arrays.copyOf(elem,elem.length*2);
        }
    }
    public void add(int data){
        checkCapacity();
        elem[this.usedSize] = data;
        this.usedSize++;
    }

指定下标添加元素

checkPosOnAdd()判断下标是否合法,如果不合法抛出异常

public void checkPosOnAdd(int pos) throws PosIllegality{
        if(pos < 0 || pos >usedSize){
            System.out.println("不合法!");
            throw new PosIllegality("获取指定下标的元素异常: "+pos);
        }
    }
    public void add(int pos, int data){
        try{
            checkPosOnAdd(pos);
        }
        catch (PosIllegality e){
            e.printStackTrace();
            return;
        }
        checkCapacity();
        for (int i = usedSize-1; i >= pos; i--) {
            elem[i+1] = elem[i];
        }
        elem[pos] = data;
        usedSize++;
    }

自定义下标不合法异常

package mylist;
public class PosIllegality extends RuntimeException{
    public PosIllegality(String msg){
        super(msg);
    }
}

判断顺序表是否为空

public boolean isEmpty(){
        return usedSize == 0;
    }

查找指定元素是否存在

  public boolean contains(int toFind){
        if(isEmpty()){
            return false;
        }
        for (int i = 0; i < usedSize; i++) {
            if(elem[i] == toFind){
                return true;
            }
        }
        return false;
    }

查找指定元素返回下标

 public int indexOf(int toFind){
        if(isEmpty()){
            return -1;
        }
        for (int i = 0; i < usedSize; i++) {
            if(elem[i] == toFind){
                return i;
            }
        }
        return -1;
    }

获取指定下标的元素

public void checkPosOnGetAndSet(int pos) throws PosIllegality {
        if(pos < 0 || pos >= usedSize){
            System.out.println("不合法");
            throw new PosIllegality("获取指定下标的元素异常: "+pos);
        }
    }
    public int get(int pos) throws MyArrayListEmpty{
        checkPosOnGetAndSet(pos);
        if(isEmpty()){
                throw new MyArrayListEmpty("获取指定下标元素时" +
                        "顺序表为空!");
        }
            return elem[pos];
    }

顺序表为空异常

package mylist;
public class MyArrayListEmpty extends RuntimeException{
    public MyArrayListEmpty(String msg){
        super(msg);
    }
}

修改指定下标元素的值

public void set(int pos, int value){
        checkPosOnGetAndSet(pos);
        elem[pos] = value;
    }

删除指定元素

  public void remove(int toRemove){
        int index = indexOf(toRemove);
        if(index == -1){
            System.out.println("没有找到");
            return;
        }
        for (int i = index; i < usedSize - 1; i++) {
            elem[i] =elem[i+1];
        }
        usedSize--;
    }

顺序表长度

  public int size(){
        return this.usedSize;
    }

回收顺序表

public void clear() {
        usedSize = 0;
    }

完整代码

package mylist;
import java.util.Arrays;
public class MyList implements IList{
    public int[] elem ;
    public int usedSize;//0
    //顺序表的 默认大小
    public static final int DEFAULT_SIZE = 10;
    public MyList(){
        this.elem = new int[DEFAULT_SIZE];
    }
    public MyList(int capacity){
        this.elem = new int[capacity];
    }
    public void display(){
        for (int i = 0; i < usedSize; i++) {
            System.out.print(elem[i]+" ");
        }
        System.out.println();
    }
     public boolean isFull(){
        return usedSize == elem.length;
     }
    private void checkCapacity(){
        if(isFull()){
            elem = Arrays.copyOf(elem,elem.length*2);
        }
    }
    public void add(int data){
        checkCapacity();
        elem[this.usedSize] = data;
        this.usedSize++;
    }
    public void checkPosOnAdd(int pos) throws PosIllegality{
        if(pos < 0 || pos >usedSize){
            System.out.println("不合法!");
            throw new PosIllegality("获取指定下标的元素异常: "+pos);
        }
    }
    public void add(int pos, int data){
        try{
            checkPosOnAdd(pos);
        }
        catch (PosIllegality e){
            e.printStackTrace();
            return;
        }
        checkCapacity();
        for (int i = usedSize-1; i >= pos; i--) {
            elem[i+1] = elem[i];
        }
        elem[pos] = data;
        usedSize++;
    }
    public boolean isEmpty(){
        return usedSize == 0;
    }
    public boolean contains(int toFind){
        if(isEmpty()){
            return false;
        }
        for (int i = 0; i < usedSize; i++) {
            if(elem[i] == toFind){
                return true;
            }
        }
        return false;
    }
    public int indexOf(int toFind){
        if(isEmpty()){
            return -1;
        }
        for (int i = 0; i < usedSize; i++) {
            if(elem[i] == toFind){
                return i;
            }
        }
        return -1;
    }
    public void checkPosOnGetAndSet(int pos) throws PosIllegality {
        if(pos < 0 || pos >= usedSize){
            System.out.println("不合法");
            throw new PosIllegality("获取指定下标的元素异常: "+pos);
        }
    }
    public int get(int pos) throws MyArrayListEmpty{
        checkPosOnGetAndSet(pos);
        if(isEmpty()){
                throw new MyArrayListEmpty("获取指定下标元素时" +
                        "顺序表为空!");
        }
            return elem[pos];
    }
    public void set(int pos, int value){
        checkPosOnGetAndSet(pos);
        elem[pos] = value;
    }
    public void remove(int toRemove){
        int index = indexOf(toRemove);
        if(index == -1){
            System.out.println("没有找到");
            return;
        }
        for (int i = index; i < usedSize - 1; i++) {
            elem[i] =elem[i+1];
        }
        usedSize--;
    }
    public int size(){
        return this.usedSize;
    }
    public void clear() {
        usedSize = 0;
    }
}
目录
相关文章
|
4天前
|
存储 安全 Java
从源码到场景,用 5 分钟讲透 Array 和 ArrayList 的差异
大家好,我是小米,29岁的技术分享者。今天聊聊社招面试中常见的问题——Array和ArrayList的区别。数组是固定大小的容器,长度不可变,性能高;ArrayList是动态数组,可自动扩容,支持更多操作但性能稍逊。在实际开发中,根据需求选择:高性能、固定大小选数组;灵活操作选ArrayList。希望这篇文章能帮你答出漂亮的答案!欢迎关注我的微信公众号“软件求生”,获取更多技术干货。
19 5
|
存储 Java 索引
【零基础学Java】—ArrayList集合概述和基本使用(十四)
【零基础学Java】—ArrayList集合概述和基本使用(十四)
|
7月前
|
Java 开发者 索引
Java List全攻略:从ArrayList到LinkedList,一网打尽!
【6月更文挑战第17天】Java List详解:ArrayList依赖动态数组,擅长随机访问和遍历,适合少次插入删除;LinkedList基于双向链表,插入删除高效,尤其在头尾操作,但随机访问慢。选择取决于应用场景,理解特性以优化代码。探索ArrayList与LinkedList,提升编程效率!
87 0
|
7月前
|
存储 Java API
JavaSE——常用API(3/3)-ArrayList入门、ArratList使用、ArrayList综合案例
JavaSE——常用API(3/3)-ArrayList入门、ArratList使用、ArrayList综合案例
56 0
|
8月前
|
存储 Java
【Java基础】Collections集合概述和使用、ArrayList集合存储学生并排序及斗地主案例
【Java基础】Collections集合概述和使用、ArrayList集合存储学生并排序及斗地主案例
73 0
|
Java
图书管理借阅系统【Java简易版】Java三大特征封装,继承,多态的综合运用
图书管理借阅系统【Java简易版】Java三大特征封装,继承,多态的综合运用
120 0
|
Java
Java List操作好帮手:ListUtil工具类实用技巧
Java List操作好帮手:ListUtil工具类实用技巧
183 0
|
Java 测试技术
20、Java——迷你图书管理器(对象+集合)
20、Java——迷你图书管理器(对象+集合)
167 0
|
存储 Java
Java中Map集合概述特点、基本功能、获取功能及Map集合的两种遍历方式
Map集合概述特点、基本功能、获取功能及Map集合的两种遍历方式的简单示例
179 0
|
Java 测试技术
14、Java——迷你图书管理器(对象+数组)
14、Java——迷你图书管理器(对象+数组)
176 0

热门文章

最新文章