目前我正在使用python进行数据结构课程。 在本书中,他们包含了两个不同的类来实现一维数组结构和二维数组。
对于1D阵列:
import ctypes
class Array:
def __init__(self, size):
assert size > 0, "Array size must be > 0"
self._size = size
PyArrayType = ctypes.py_object * size
self._elements = PyArrayType()
self.clear(None)
def len(self):
return self._size
def getitem(self, index):
assert index >= 0 and index < self.len(), "Array subscript out of range"
return self._elements[index]
def setitem(self, index, value):
assert 0 <= index < self.len(), "Array subscript out of range"
self._elements[index] = value
def clear(self, value):
for i in range(self.len()):
self._elements[i] = value
def iter(self):
return ArrayIterator(self._elements )
class ArrayIterator:
def __init__(self, theArray):
self._arrayRef = theArray
self._curNdx = 0
def __iter__(self):
return self
def __next__(self):
if self._curNdx < len(self._arrayRef):
entry = self._arrayRef[self._curNdx]
self._curNdx += 1
return entry
else:
raise StopIteration
class Array2D :
def __init__( self, numRows, numCols ):
self._theRows = Array( numRows )
for i in range( numRows ) :
self._theRows[i] = Array( numCols )
def numRows( self ):
return len( self._theRows )
def numCols( self ):
return len( self._theRows[0] )
def clear( self, value ):
for row in range( self.numRows() ):
row.clear( value )
def __getitem__( self, ndxTuple ):
assert len(ndxTuple) == 2, "Invalid number of array subscripts."
row = ndxTuple[0]
col = ndxTuple[1]
assert row >= 0 and row < self.numRows() \
and col >= 0 and col < self.numCols(), \
"Array subscript out of range."
the1dArray = self._theRows[row]
return the1dArray[col]
def __setitem__( self, ndxTuple, value ):
assert len(ndxTuple) == 2, "Invalid number of array subscripts."
row = ndxTuple[0]
col = ndxTuple[1]
assert row >= 0 and row < self.numRows() \
and col >= 0 and col < self.numCols(), \
"Array subscript out of range."
the1dArray = self._theRows[row]
the1dArray[col] = value
我使用以下代码来了解它是如何工作的:
arr = Array(5)
arrLen = arr.len()
arr.clear(0)
for i in range (arrLen):
print arr.getitem(i)
print "The length of the array = ",arrLen
print "Enter 5 numbers"
for i in range (arrLen):
#n = raw_input("num = ")
arr.setitem(i,i)
for i in range (arrLen):
print arr.getitem(i)
print"values are ", arr.iter()
但是,我不知道如何调用2D数组来理解它是如何工作的。
ArrMulti = Array2D(3, 4)
我收到以下错误:
File "MultiArrayADT.py", line 46, in __init__
self._theRows[i] = Array( numCols )
AttributeError: Array instance has no attribute '__setitem__'
所以请有人告诉我如何创建2D数组对象。
答案 0 :(得分:2)
在Array
课程中,您应该覆盖方法__setitem__()
,同时实施setitem()
。因此,尝试更改方法的名称。这应该工作。与getitem()
相同。