Challenge: Eigenvalue of matrix #3
Subdomeniu: Linear Algebra Foundations (linear-algebra-foundations)
Scor cont: 5.0 / 5
Submission status: Accepted
Submission score: 1.0
Submission ID: 464718497
Limbaj: python3
Link challenge: https://www.hackerrank.com/challenges/eigenvalues-of-matrix-3/problem
Cerinta
Find the eigenvalues of **A** and **A<sup>2</sup>** where **A** is -
<img src="https://s3.amazonaws.com/hr-challenge-images/0/1445184582-dc6dfbe48f-Screenshotfrom2015-10-18213932.png" title="Screenshot from 2015-10-18 21:39:32.png" />
Your answer should have the eigenvalues of **A** followed by eigenvalues of **A<sup>2</sup>** separated by a single line resembling this(with smaller value coming first):
<pre>
5
6
2
3
</pre>
Cod sursa
def determinant(A: list[list[int]]) -> int:
return A[0][0]*A[1][1] - A[1][0]*A[0][1]
def matrixSubtract(B: list, A: list) -> list:
C = [[0, 0], [0, 0]]
for i in range(len(B)):
for j in range(len(B[0])):
C[i][j] = B[i][j] - A[i][j]
return C
def scalarMultiply(A: list, k: int) -> list:
Ak = [[0, 0], [0, 0]]
for i in range(len(A)):
for j in range(len(A[0])):
Ak[i][j] = k*A[i][j]
return Ak
def matrixSquared(A: list) -> list:
A2 = [[0, 0], [0, 0]]
for i in range(len(A)):
for j in range(len(A[0])):
for k in range(len(A[0])):
A2[i][j] += A[i][k] * A[k][j]
return A2
if __name__ == "__main__":
A = [[2, -1], [-1, 2]]
I2 = [[1, 0], [0, 1]] # 2 x 2 identity matrix
A2 = matrixSquared(A)
eigval1, eigval2 = -50, -50
lst_eigvals = []
while (eigval1 < 50):
val1 = determinant(matrixSubtract(scalarMultiply(I2, eigval1), A))
if (val1 == 0): # |lambdaI - A| = 0
lst_eigvals += [eigval1]
eigval1 += 1
while (eigval2 < 50):
val2 = determinant(matrixSubtract(scalarMultiply(I2, eigval2), A2))
if (val2 == 0): # |lambdaI - A| = 0
lst_eigvals += [eigval2]
eigval2 += 1
print(*lst_eigvals, sep='\n')
HackerRank Linear Algebra Foundations – Eigenvalue of matrix #3
