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