数组的增删CRUD

今天突然思考一个问题,数组的增删改查我好像还没实现过,于是就利用System.arraycopy简单的实现了一下:

    /**
     * 实现数组的增加元素操作
     * @param array 目标数组
     * @param number 增加的元素
     * @param index 要添加的位置索引
     * @return 增加元素后的新数组
     */
    public int[] create(int[] array,int number,int index){
        int[] newArray = new int[array.length+1];
        System.arraycopy(array,0,newArray,0,index);
        newArray[index] = number;
        System.arraycopy(array, index, newArray, index+1, array.length-index);
        
        return newArray;
    }
    /**
     * 实现数组的delete操作
     * @param array 目标数组
     * @param index 索引位置
     * @return  删除后的新数组
     */
    public int[] delete(int[] array,int index){
        int[] newArray = new int[array.length-1];
        System.arraycopy(array, 0, newArray, 0, index);
        System.arraycopy(array, index+1, newArray, index, array.length-index-1);
        return newArray;
    }
    /**
     * 判断数组中是否含有该元素
     * @param array 目标数组
     * @param number 目标元素
     * @return 含有该元素的个数
     */
    public int retrieve(int[] array,int number){
        int index = 0;
        for(int i : array){
            if(i==number)      index++;    
        }
        return index;
    }

为了简单我直接用int数组来实现,可以换成Object。

原文地址:https://www.cnblogs.com/xiaoweihua/p/7019053.html