Возврат количества столбцов / самой длинной строки в двумерном массиве и удаление строки - PullRequest
0 голосов
/ 11 мая 2018

Я работаю над заданием, пытаясь спроектировать два абстрактных типа данных в Python 3. У меня вопрос к подклассу "dnmMtx". Я ищу руководство по возвращению числа столбцов вместе с самой длинной строкой в ​​этом подклассе."функция, а также пытается выяснить, как удалить строку.Сначала я подумал, что могу вытолкнуть строку или использовать опцию .delete, но ни одна из них не сработала.Кроме того, в настоящее время моя функция размера возвращает количество строк.Спасибо за любую помощь, спасибо!

class DnmArr:

    def __init__(self):

        #create empty list
        self.arr=[]

    def __del__(self):
        print('Deconstructed')

    #return length
    def length(self):
        return len(self.arr)

    #append
    def append(self, x):
        #add x to arr
        if type(x) == int:
            self.arr.append(x)
        else:
            print('Not an integer.')

    #delete
    def delete(self,x):
        index = x
        #if element is present in array
        if index <= len(self.arr):
            self.arr.pop(index)
        else:
            print('Element does not exist.')


    def value(self, x):        
        if x <= len(self.arr) and type(x) == int:
            print(self.arr[x-1])
        else:
            print('Does not exist or list indices is not an integer')




#initializing subclass using parent
class DnmMtx(DnmArr):

    def __init__(self):
        DnmArr.__init__(self)
        self.arr=[[],[]] #creating 2d array

    def __del__(self):
        print('Deconstructed')

    def addrow(self):
        row = []
        self.arr.append(row)

    def delrow(self, x):
        if type(x) == int:
            self.arr.delete(arr[x])
        else:
            print('row does not exist/invalid row')

    def size(self):
         return len(self.arr)

    def append(self, x, y):
        if type(x) and type(y) == int:
            self.arr[x].append(y)
        else:
            print('Not an integer.')

    def delete(self, x, y):
        #if element is present
        if y <= len(self.arr[x]) and x <= len(self.arr): #check 
            self.arr[x].pop(y)
        else:
            print('Element does not exist.')

    def value(self, x, y):
        if x and y <= len(self.arr) and type(x) and type(y) == int:
            print(self.arr[x-1][y-1])
        else:
            print('Does not exist or list indices is not an integer')



#create object of type Dynamic Array
a = DnmArr()

b = DnmMtx()

1 Ответ

0 голосов
/ 11 мая 2018

Ваш self.arr.pop(index) вызов должен работать и для строк.list не знает, что его элементы также являются списками.

Вы также можете удалить строку в списке списков, выполнив

del self.arr[row_index]

Например

arr = [[1,2,3], [4,5,6]]
del arr[0]
print(arr) # --> [[4, 5, 6]]
...