Array && Dynamic Array

Array(数组)

盛有单一类型固定数量值的容器类

  • 以0开始的索引
  • 有数组长度属性(长度不一定等于容器大小)
  • 内存表示(连续的)
  • 边界检查

Dynamic Array(ADT 抽象数据类型)

  • 数组的容量动态可变
  • 存放的东西不限制类型

自定义动态数组

# -*- coding:utf-8 -*-
# @Author :xuchaoqiang

import ctypes


class DynamicArray:

    def __init__(self):
        # Create an empty array
        self._n = 0  # size
        self._capacity = 10
        self._A = self._make_array(self._capacity)

    # len(list)
    def __len__(self):
        return self._n

    def is_empty(self):
        return self._n == 0

    # O(1)
    def __getitem__(self, k):
        if not 0 <= k < self._n:
            raise ValueError('invalid index')
        return self._A[k]

    # O(1)
    def append(self, obj):
        if self._n == self._capacity:
            self._resize(2 * self._capacity)
        self._A[self._n] = obj
        self._n += 1

    def _make_array(self, c):
        return (c * ctypes.py_object)()

    def _resize(self, c):
        B = self._make_array(c)
        for k in range(self._n):
            B[k] = self._A[k]
        self._A = B
        self._capacity = c

    # O(n)
    def insert(self, k, value):
        if self._n == self._capacity:
            self._resize(2 * self._capacity)
        for j in range(self._n, k, -1):
            self._A[j] = self._A[j - 1]
        self._A[k] = value
        self._n += 1

    # O(n)
    def remove(self, value):
        for k in range(self._n):
            if self._A[k] == value:
                for j in range(k, self._n - 1):
                    self._A[j] = self._A[j + 1]
                self._A[self._n - 1] = None
                self._n -= 1
                return
        raise ValueError('value not found')

    def _print(self):
        for i in range(self._n):
            print(self._A[i], end=' ')
        print()


if __name__ == '__main__':
    mylist = DynamicArray()
    print('size was: ', str(len(mylist)))
    mylist.append(10)
    mylist.append(20)
    mylist.append(30)
    mylist.insert(0, 0)
    mylist.insert(1, 5)
    mylist.insert(3, 15)
    mylist._print()
    mylist.remove(20)
    mylist._print()

    print('size is: ', str(len(mylist)))

Python List各个操作的时间复杂度

 

 

 

 

posted @ 2020-05-07 19:59  下山打老虎i  阅读(279)  评论(0编辑  收藏  举报