2018-10-04 05:19:11 +08:00
|
|
|
#
|
|
|
|
# 1) Insertion, deletion and random access of array
|
|
|
|
# 2) Assumes int for element type
|
|
|
|
#
|
|
|
|
# Author: Wenru
|
|
|
|
#
|
2018-12-25 15:29:22 +08:00
|
|
|
|
|
|
|
|
2018-10-04 05:19:11 +08:00
|
|
|
class MyArray:
|
|
|
|
"""A simple wrapper around List.
|
|
|
|
You cannot have -1 in the array.
|
|
|
|
"""
|
2018-10-21 21:03:14 +08:00
|
|
|
|
2018-10-04 05:19:11 +08:00
|
|
|
def __init__(self, capacity: int):
|
|
|
|
self._data = []
|
|
|
|
self._capacity = capacity
|
2018-11-06 11:17:07 +08:00
|
|
|
|
2018-12-25 15:29:22 +08:00
|
|
|
def __getitem__(self, position: int) -> object:
|
2018-10-04 05:19:11 +08:00
|
|
|
return self._data[position]
|
|
|
|
|
2018-12-25 15:29:22 +08:00
|
|
|
def __setitem__(self, index: int, value: object):
|
|
|
|
self._data[index] = value
|
2018-10-21 21:03:14 +08:00
|
|
|
|
2018-12-25 15:29:22 +08:00
|
|
|
def __len__(self) -> int:
|
|
|
|
return len(self._data)
|
|
|
|
|
|
|
|
def __iter__(self):
|
|
|
|
for item in self._data:
|
|
|
|
yield item
|
|
|
|
|
|
|
|
def find(self, index: int) -> object:
|
|
|
|
try:
|
|
|
|
return self._data[index]
|
|
|
|
except IndexError:
|
2018-11-06 11:17:07 +08:00
|
|
|
return None
|
2018-10-04 05:19:11 +08:00
|
|
|
|
|
|
|
def delete(self, index: int) -> bool:
|
2018-12-25 15:29:22 +08:00
|
|
|
try:
|
|
|
|
self._data.pop(index)
|
|
|
|
return True
|
|
|
|
except IndexError:
|
2018-11-06 11:17:07 +08:00
|
|
|
return False
|
|
|
|
|
2018-10-04 05:19:11 +08:00
|
|
|
def insert(self, index: int, value: int) -> bool:
|
2018-12-25 15:29:22 +08:00
|
|
|
if len(self) >= self._capacity:
|
2018-11-06 11:17:07 +08:00
|
|
|
return False
|
2018-10-15 11:05:22 +08:00
|
|
|
else:
|
2018-12-25 15:29:22 +08:00
|
|
|
return self._data.insert(index, value)
|
2018-10-04 05:19:11 +08:00
|
|
|
|
|
|
|
def print_all(self):
|
2018-12-25 15:29:22 +08:00
|
|
|
for item in self:
|
|
|
|
print(item)
|
2018-10-04 05:19:11 +08:00
|
|
|
|
2018-11-06 11:17:07 +08:00
|
|
|
|
|
|
|
def test_myarray():
|
2018-12-25 15:29:22 +08:00
|
|
|
array = MyArray(5)
|
|
|
|
array.insert(0, 3)
|
|
|
|
array.insert(0, 4)
|
|
|
|
array.insert(1, 5)
|
|
|
|
array.insert(3, 9)
|
|
|
|
array.insert(3, 10)
|
|
|
|
assert array.insert(0, 100) is False
|
|
|
|
assert len(array) == 5
|
|
|
|
assert array.find(1) == 5
|
|
|
|
assert array.delete(4) is True
|
|
|
|
array.print_all()
|
2018-11-06 11:17:07 +08:00
|
|
|
|
|
|
|
|
2018-10-04 05:19:11 +08:00
|
|
|
if __name__ == "__main__":
|
2018-12-25 15:29:22 +08:00
|
|
|
test_myarray()
|