zoukankan      html  css  js  c++  java
  • 数据结构篇-数组(TypeScript版+Java版)

    1.TypeScript版本

    export default class MyArray<E> {
    
      public data: E[];
      public size: number = 0;
    
      /**
       * 构造函数,传入数组的容量capacity
       * @param {number} capacity 数组容量,默认10
       */
      constructor(capacity = 10) {
        this.data = new Array(capacity);
      }
    
      /**
       * 获取数组容量(数组能总共能包含多少元素)
       * Time Complexity O(1)
       * @return {number}
       */
      getCapacity(): number {
        return this.data.length;
      }
    
      /**
       * 获取数组中当前存储元素的个数
       * Time Complexity O(1)
       * @return {number}
       */
      getSize(): number {
        return this.size;
      }
    
      /**
       * 判断数组是否为空,即元素的个数是否为0
       * Time Complexity O(1)
       * @return {boolean}
       */
      isEmpty(): boolean {
        return this.size === 0;
      }
    
      /**
       * 在数组中index位置添加一个元素
       * 考虑到这里不是每次操作都会触发扩容,这里均摊到每次操作上的时间复杂度为O(1)
       * @param {number} index 要插入的位置
       * @param {E} e 要插入的元素
       * @return {void}
       */
      add(index: number, e: E): void {
        if (index < 0 || index > this.size) {
          throw new Error('Add failed. Required index >= 0 and index <= size');
        }
    
        // 将数组的容量扩大为之前的二倍
        if (this.size === this.data.length) {
          this.resize(this.data.length * 2);
        }
        for (let i = this.size - 1; i >= index; i--) {
          this.data[i + 1] = this.data[i];
        }
        this.data[index] = e;
        this.size++;
      }
    
      /**
       * 向所有元素之后添加一个元素
       * Time Complexity O(1)
       * @param {E} e 要插入的元素
       * @return {void}
       */
      addLast(e: E): void {
        this.add(this.size, e);
      }
    
      /**
       * 向所有元素之前添加一个元素
       * Time Complexity O(n)
       * @param {E} e 要插入的元素
       * @return {void}
       */
      addFirst(e: E): void {
        this.add(0, e);
      }
    
      /**
       * 修改index索引位置元素为e
       * Time Complexity O(1)
       * @param {number} index 要插入元素的位置
       * @param {E} e 要插入的元素
       * @return {void}
       */
      set(index: number, e: E) {
        if (index < 0 || index >= this.size) {
          throw new Error('Set failed. Index is illegal.');
        }
        this.data[index] = e;
      }
    
      /**
       * 查找数组中是否含有元素e
       * Time Complexity O(n)
       * @param {E} e 要查找的元素
       * @return {boolean}
       */
      contains(e: E): boolean {
        for (let i = 0; i < this.size; i++) {
          if (e === this.data[i]) {
            return true;
          }
        }
        return false;
      }
    
      /**
       * 查找数组中元素e所在的索引,如果不存在,则返回-1
       * Time Complexity O(n)
       * @param {E} e 要查找的元素
       * @return {boolean}
       */
      find(e: E): number {
        for (let i = 0; i < this.size; i++) {
          if (e === this.data[i]) {
            return i;
          }
        }
        return -1;
      }
    
      /**
       * 从数组中删除index位置的元素,并且返回删除元素
       * Time Complexity O(n)
       * @param {number} index 要删除的元素位置的索引
       * @return {E}
       */
      remove(index: number): E {
        if (index < 0 || index > this.size) {
          throw new Error('Remove failed. index is illegal')
        }
    
        let ret: E = this.data[index];
        for (let i = index + 1; i < this.size; i++) {
          this.data[i - 1] = this.data[i];
        }
        this.size--;
        this.data[this.size] = null;
        // 当size == capacity / 4时,才将capacity减半。防止复杂度震荡
        // data.length != 0 是因为不能常见capacity为0的数组
        if (this.size === Math.floor(this.data.length / 4) && Math.floor(this.data.length / 2) !== 0) {
          this.resize(Math.floor(this.data.length / 2));
        }
        return ret;
      }
    
      /**
       * 删除数组中的最后一个元素
       * Time Complexity O(1)
       * @return {E}
       */
      removeLast(): E {
        return this.remove(this.size - 1);
      }
    
      /**
       * 删除数组中的第一个元素
       * Time Complexity O(n)
       * @return {E}
       */
      removeFirst(): E {
        return this.remove(0);
      }
    
      /**
       * 获取index索引的元素
       * Time Complexity O(1)
       * @param {number} index 要获取元素的索引
       * @return {E}
       */
      get(index: number): E {
        if (index < 0 || index >= this.size) {
          throw new Error('Get failed. Index is illegal...')
        }
        return this.data[index];
      }
    
      /**
       * 获取数组中的第一个元素
       * Time Complexity O(1)
       * @return {E}
       */
      getFirst() {
        return this.get(0);
      }
    
      /**
       * 获取数组中的最后一个元素
       * Time Complexity O(1)
       * @return {E}
       */
      getLast() {
        return this.get(this.size - 1);
      }
    
      /**
       * 数组扩容,或者缩容操作
       * Time Complexity O(n)
       * @param {number} newCapacity 新的数组的容量
       * @return {void}
       */
      resize(newCapacity: number): void {
        let newData: E[] = new Array(newCapacity);
        for (let i = 0; i < this.size; i++) {
          newData[i] = this.data[i];
        }
    
        this.data = newData;
      }
    
      /**
       * 交换数组中的i, j两个元素
       * Time Complexity O(1)
       * @param {number} i 第i位置的元素
       * @param {number} j 第j位置的元素
       * @return {void}
       */
      swap(i: number, j: number): void {
        if (i < 0 || j < 0 || i >= this.size || j >= this.size) {
          throw new Error('Index is illegal.');
        }
        let temp = this.data[i];
        this.data[i] = this.data[j];
        this.data[j] = temp;
      }
    
      toString(): string {
        let res = '';
        res += `Array: size = ${this.size}, capacity = ${this.getCapacity()}
    `;
        res += '[';
        for (let i = 0; i < this.size; i++) {
          res += this.data[i];
          if (i !== this.size - 1)
            res += ', '
        }
        res += ']';
        return res;
      }
    }
    

    2.Java版本

    public class Array<E> {
        private E[] data;
        private int size;
    
        // 构造函数,传入数组的容量capacity
        public Array(int capacity) {
            data = (E[])new Object[capacity];
            size = 0;
        }
    
        // 无参数构造函数,默认数组的容量capacity=10
        public Array() {
            this(10);
        }
    
        // 构函函数,传进来的是数组
        public Array(E[] arr) {
            data = (E[])new Object[arr.length];
            for (int i = 0; i < arr.length; i++)
                data[i] = arr[i];
            size = arr.length;
        }
    
        // 获取数组中有效元素的个数
        public int getSize() {
            return size;
        }
    
        // 获取数组的容量
        public int getCapacity() {
            return data.length;
        }
    
        // 判断数组是否为空
        public boolean isEmpty() {
            return size == 0;
        }
    
        // Time Complexity O(1)
        // 向数组的末尾添加一个元素e
        public void addLast(E e) {
            add(size, e);
        }
    
        // Time Complexity O(n)
        // 向数组的头部添加一个元素e
        public void addFirst(E e) {
            add(0, e);
        }
    
        // Time Complexity O(n)
        // 在第index位置插入一个新元素e
        // 均摊时间复杂度
        // 假设capacity=n, 经过n+1次的addLast操作,触发resize,总共进行2n+1次基本操作
        // 因此平均每次addLast操作,进行2次的基本操作
        public void add(int index, E e) {
            if (index < 0 || index > size)
                throw new IllegalArgumentException("AddLast failed. Require index >=0 and index <= size");
    
            // 如果数组已满,则扩容1倍
            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++;
        }
    
        // Time Complexity O(1)
        // 获取index索引位置的元素
        public E get(int index) {
            if (index < 0 || index > size)
                throw new IllegalArgumentException("Get failed. Index is illegal.");
            return data[index];
        }
    
        // 获取数组的第一个元素
        public E getFirst() {
            return get(0);
        }
    
        // 获取数组的最后一个元素
        public E getLast() {
            return get(size - 1);
        }
    
        // Time Complexity O(1)
        // 修改index位置的元素为e
        public void set(int index, E e) {
            if (index < 0 || index > size)
                throw new IllegalArgumentException("Set failed. Index is illegal.");
            data[index] = e;
        }
    
        // Time Complexity O(n)
        // 查找数组中是否包含元素e
        public boolean contains(E e) {
            for (int i = 0; i < size; i++) {
                if (data[i].equals(e))
                    return true;
            }
            return false;
        }
    
        // Time Complexity O(n)
        // 查找数组中元素e所在的索引,如果不存在元素e,就返回-1
        public int find(E e) {
            for (int i = 0; i < size; i++) {
                if (data[i].equals(e))
                    return i;
            }
            return -1;
        }
    
        // Time Complexity O(n)
        // 删除指定位置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--;
            data[size] = null;
    
            // 当size == capacity / 4时,才将capacity减半。防止复杂度震荡
            // data.length != 0 是因为不能常见capacity为0的数组
            if (size == data.length / 4 && data.length / 2 != 0)
                resize(data.length / 2);
            return ret;
        }
    
        // Time Complexity O(n)
        // 从数组中删除第一个元素,并返回删除的元素
        public E removeFirst() {
            return remove(0);
        }
    
        // Time Complexity O(1)
        // 从数组中删除最后一个元素,并返回删除的元素
        public E removeLast() {
            return remove(size - 1);
        }
    
        // Time Complexity O(n)
        // 从数组中删除元素e
        public void removeElement(E e) {
            int index = find(e);
            if (index != -1)
                remove(index);
        }
    
        private void resize(int newCapacity) {
            E[] newData = (E[])new Object[newCapacity];
            for (int i = 0; i < size; i++) {
                newData[i] = data[i];
            }
            data = newData;
        }
    
        public void swap(int i, int j) {
            if (i < 0 || i >= size || j < 0 || j >= size)
                throw new IllegalArgumentException("Index is illegal.");
            E ret = data[i];
            data[i] = data[j];
            data[i] = ret;
        }
    
        // 覆盖父类的toString方法
        @Override
        public String toString() {
            StringBuilder res = new StringBuilder();
            res.append(String.format("Array: size = %d, capacity = %d
    ", 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();
        }
    }
    

    更多数据结构和leetcode解法问题,请参考我的githubhttps://github.com/GuoLizhi/algorithm

  • 相关阅读:
    【一天一个canvas】制作渐变式PPT背景(十五)
    【一天一个canvas】写文字(十四)
    【一天一个canvas】图像切割函数clip(十三)
    ThinkPHP 3.2 大写字母函数封装方法实例
    百度echarts 地图使用实例
    随机数生成
    需要修改php.ini文件支持操作,可不用直接操作php.ini
    定时多少时间调用指定URL
    自动调用接口
    tp5 Excel 批量导入
  • 原文地址:https://www.cnblogs.com/guolizhi/p/12715536.html
Copyright © 2011-2022 走看看