Challenge: Linear Algebra Foundations #7 – The 1000th Power of a Matrix
Subdomeniu: Linear Algebra Foundations (linear-algebra-foundations)
Scor cont: 5.0 / 5
Submission status: Accepted
Submission score: 1.0
Submission ID: 464718836
Limbaj: python3
Link challenge: https://www.hackerrank.com/challenges/linear-algebra-foundations-7-the-1000th-power-of-a-matrix/problem
Cerinta
You are provided a matrix $A$ =
[-2 -9 ]
[ 1 4 ]
The 1000<sup>th</sup> power of $A$, i.e. $A$<sup>1000</sup> =
[A B]
[C D]
In the text box below, enter the integers $A$, $B$, $C$ and $D$ each on a new line, respectively. Do not leave any leading or trailing spaces.
Cod sursa
def matrix_mul(A, B):
ROWS_A, COLS_A = len(A), len(A[0])
ROWS_B, COLS_B = len(B), len(B[0])
assert COLS_A == ROWS_B
COMMON_D = ROWS_B
# zeros for Rows-A x Cols-B
M_TIMES = []
for r in range(ROWS_A):
M_TIMES.append( [0] * COLS_B )
# Loop over Rows-A, then Cols-B, then the common dimension
for rA in range(ROWS_A):
for cB in range(COLS_B):
for t in range(COMMON_D):
M_TIMES[rA][cB] += A[rA][t]*B[t][cB]
return M_TIMES
def print_matrix(M, skip_indexes=[]):
ROWS, COLS = len(M), len(M[0])
for r in range(ROWS):
for c in range(COLS):
if skip_indexes and skip_indexes[r][c]:
continue
print(M[r][c])
#####
A = [[-2,-9],[1,4]]
B = A
EXP=1000
for _ in range(EXP-1):
B = matrix_mul(B, A)
# print(B)
print_matrix(B)
HackerRank Linear Algebra Foundations – Linear Algebra Foundations #7 – The 1000th Power of a Matrix
