1. Реализуйте класс Matrix. Он должен содержать:
Конструктор от списка списков. Гарантируется, что списки состоят из чисел, не пусты и все имеют одинаковый размер. Конструктор должен копировать содержимое списка списков, т.е. при изменении списков, от которых была сконструирована матрица, содержимое матрицы изменяться не должно.
Метод __str__ переводящий матрицу в строку. При этом элементы внутри одной строки должны быть разделены знаками табуляции, а строки — переносами строк. При этом после каждой строки не должно быть символа табуляции и в конце не должно быть переноса строки.
Метод size без аргументов, возвращающий кортеж вида (число строк, число столбцов)
На проверку вы должны сдать только файл, содержащий описание класса и одну строку вне класса (в качестве основной программы):
exec(stdin.read())
И в начале файла:
from sys import stdin
Для тестирования класса вы можете вместо строки exec(stdin.read()) вставлять код из примеров или писать свой код.
Формат ввода
Вводится исходный код тестирующей программы на языке Python.
Формат вывода
Выведите результат её работы в текущем окружении при помощи exec как это указано в условии.
2. Добавьте в предыдущий класс следующие методы:
__add__ принимающий вторую матрицу того же размера и возвращающий сумму матриц
__mul__ принимающий число типа int или float и возвращающий матрицу, умноженную на скаляр
__rmul__ делающий то же самое, что и __mul__. Этот метод будет вызван в том случае, аргумент находится справа. Можно написать __rmul__ = __mul__
В Pycharm на компьютере тест
m = Matrix([[10, 10], [0, 0], [1, 1]]) print(m.size())
(3, 2)
Может, кто-нибудь сможет посоветовать, что исправить?
from sys import stdin from copy import deepcopy import numpy class Matrix: def __init__(self, list_of_lists): self.matrix = deepcopy(list_of_lists) def __str__(self): return '\n'.join('\t'.join(map(str, row)) for row in self.matrix) def size(self): sizepair = (len(self.matrix), len(self.matrix[0])) return sizepair def __getitem__(self, idx): return self.matrix[idx] def __add__(self, other): other = numpy.matrix(other) result = [] numbers = [] for i in range(len(self.matrix)): for j in range(len(self.matrix[0])): summa = other[i][j] + self.matrix[i][j] numbers.append(summa) if len(numbers) == len(self.matrix): result.append(numbers) numbers = [] return Matrix(result) def __mul__(self, other): m1 = numpy.array(self.matrix) return Matrix(m1 * other) def __rmul__(self, other): m2 = numpy.array(self.matrix) return Matrix(other * m2) exec(stdin.read())