数据结构之数组篇

最近想写点数据结构方面的东西,这不首篇介绍下最基础的数据结构数组的一些知识点!

首先,数组的特点 适合查询,但是删除和修改有点慢!

话不多说,先看看手动实现的数组类Array吧! talk is poor , show me the codeing!

package com.hl.array;

/**
 * Created by 帅气的黑天鹅丶 on 2018/7/30.
 */
public class Array<E> {
    private E[] data;
    private int size;

    // 构造函数,传入数组的容量capacity构造Array
    public Array(int capacity){
        data = (E[])new Object[capacity];
        size =0;
    }

    // 无参数的构造函数,默认数组的容量capacity=10
    public Array(){
        this(10);
    }

    // 获取数组的容量
    public int getCapacity(){
        return data.length;
    }

    // 获取数组中的元素个数
    public int getSize(){
        return size;
    }

    // 返回数组是否为空
    public boolean isEmpty(){
        return size == 0;
    }

    // 在index索引的位置插入一个新元素e
    public void add(int index,E e){
        /*if (size==data.length)
            throw new IllegalArgumentException("add is failed,array is full");*/

        if (index<0 || index>size)
            throw new IllegalArgumentException("Add failed. Require index >= 0 and index <= size.");

        if (size==data.length)
            resize(2*data.length);

        for (int i=size-1;i>=index;i--){
            data[i+1] = data[i];
        }
        data[index]=e;
        size++;
    }

    // 向所有元素后添加一个新元素
    public void addLast(E e){
        add(size,e);
    }

    // 在所有元素前添加一个新元素
    public void addFirst(E e){
        add(0,e);
    }

    // 获取index索引位置的元素
    public E get(int index){
        if(index < 0 || index >= size)
            throw new IllegalArgumentException("Get failed. Index is illegal.");
        return data[index];
    }

    // 修改index索引位置的元素为e
    public void set(int index,E e){
        if(index < 0 || index >= size)
            throw new IllegalArgumentException("Get failed. Index is illegal.");
        data[index] = e;
    }

    // 查找数组中是否有元素e
    public boolean contains(E e){
        for (int i=0;i<size;i++){
            if (data[i].equals(e))
                return true;
        }
        return false;
    }

    // 查找数组中元素e所在的索引,如果不存在元素e,则返回-1
    public int find(E e){
        for (int i=0;i<size;i++){
            if (data[i].equals(e))
                return i;
        }
        return -1;
    }

    // 从数组中删除index位置的元素, 返回删除的元素
    public E remove(int index){
        if(index < 0 || index >= size)
            throw new IllegalArgumentException("Remove failed. Index is illegal.");
        E ret = data[index];
        for (int i=index+1;i<size;i++){
            data[i-1]=data[i];
        }
        size--;

        if(size == data.length / 4 && data.length / 2 != 0)
            resize(data.length / 2);
        return ret;
    }

    // 从数组中删除第一个元素, 返回删除的元素
    public E removeFirst(){
        return remove(0);
    }

    // 从数组中删除最后一个元素, 返回删除的元素
    public E removeLast(){
        return remove(size-1);
    }
    // 从数组中删除元素e
    public void removeElement(E e){
        int index = find(e);
        if (index!=-1)
            remove(index);
    }

    @Override
    public String toString() {
        StringBuilder res = new StringBuilder();
        res.append(String.format("Array:size=%d , capacity=%d\n",size,data.length));
        res.append('[');
        for (int i=0;i<size;i++){
            res.append(data[i]);
            if (i!=size-1){
                res.append(',');
            }
        }
        res.append(']');
        return res.toString();
    }

    // 将数组空间的容量变成newCapacity大小
    //动态数组
    public void resize(int newCapacity){
        E[] newData = (E[])new Object[newCapacity];
        for (int i=0;i<size;i++){
            newData[i] = data[i];
        }
        data = newData;
    }
}

这是一个动态数组的例子,可以根据数组元素个数的变化动态的扩容(2倍)或者减容!

代码比较简单,就不做解释了!相信大家一定能够看懂!
数组虽然简单,但是大家还是需要重视一下!千万不能小瞧了它!

好了,今天的文章写到这里!重要的还是代码。

猜你喜欢

转载自www.cnblogs.com/JacobHua/p/9397425.html