PR3_Skriptsprachen_GruppeD_SL1/s1_a51.py

25 lines
775 B
Python
Raw Normal View History

2023-03-30 01:29:11 +02:00
class SparseMatrix:
2022-11-08 14:28:42 +01:00
def __init__(self):
2023-03-30 01:29:11 +02:00
self.__matrix = dict()
2022-11-08 14:28:42 +01:00
2023-03-30 01:29:11 +02:00
def save(self, matrix) -> None:
for row in range(len(matrix)):
for col in range(len(matrix[row])):
if matrix[row][col] != 0:
self.__matrix[(row, col)] = matrix[row][col]
2022-11-08 14:28:42 +01:00
2023-03-30 01:29:11 +02:00
def get(self, row, col) -> int or None:
if self.__matrix[(row, col)]:
return self.__matrix[(row, col)]
2022-11-08 14:28:42 +01:00
2023-03-30 01:29:11 +02:00
def __str__(self) -> str:
return '\n'.join(map(lambda pair: ': '.join(map(str, pair)), self.__matrix.items()))
2022-11-08 16:11:58 +01:00
2022-11-08 14:28:42 +01:00
2022-11-05 15:33:32 +01:00
if __name__ == "__main__":
2023-03-30 01:29:11 +02:00
# 5.1
sparse_matrix = SparseMatrix()
sparse_matrix.save([[3, 0, -2, 11], [0, 0, 9, 0], [0, 7, 0, 0], [0, 0, 0, 0]])
print(sparse_matrix)
print(sparse_matrix.get(0, 0))