susinlee 님의 블로그
88. 행렬의 곱셈 본문
[문제]
https://school.programmers.co.kr/learn/courses/30/lessons/12949
[풀이]
1. a x b 행렬과 c x d 행렬을 곱하면 a x d 행렬이 된다. 이때 b = c 이어야 곱셈이 가능하다.
2. arr1의 행의 길이(n)와 arr2의 열의 길이(m)를 구한다.
3. n x m 행렬 answer를 만들어준다.
3행 3열인 두 행렬의 곱셈 프로세스를 써보면 다음과 같다.
i=0, j=0 → (arr1[0][0] x arr2[0][0]) +
(arr1[0][1] x arr2[1][0]) +
(arr1[0][2] x arr2[2][0])
i=0, j=1 → (arr1[0][0] x arr2[0][1]) +
(arr1[0][1] x arr2[1][1]) +
(arr1[0][2] x arr2[2][1])
i=0, j=2 → (arr1[0][0] x arr2[0][2]) +
(arr1[0][1] x arr2[1][2]) +
(arr1[0][2] x arr2[2][2])
arr1 의 행은 i 에 따라 변화하고, arr2 의 열은 j에 따라 변화한다.
그리고 arr1 의 열과 arr2 의 행은 똑같이 변화하는데 이는 a x b, c x d 에서 b(혹은 c) 크기 만큼 0부터 순회한다.
따라서 arr1 의 열 혹은 arr2 의 행의 길이도 구해준다.
이중 for 문을 돌린 뒤 덧셈을 위한 for 문을 한번 더 돌려주면서 answer 의 요소를 채워주자.
def solution(arr1, arr2):
n = len(arr1)
m = len(arr2[0])
l = len(arr1[0])
answer = [[0]*m for _ in range(n)]
for i in range(n):
for j in range(m):
for k in range(l):
answer[i][j] += arr1[i][k] * arr2[k][j]
return answer
zip 함수를 통해 arr2 의 열을 가져오고 리스트 컴프리헨션을 활용한다면 더욱 효율적으로 처리가 가능하다.
def solution(arr1, arr2):
return [[sum(x * y for x, y in zip(row_1, col_2)) for col_2 in zip(*arr2)] for row_1 in arr1]
'코드카타 > Python' 카테고리의 다른 글
90. 의상 (0) | 2025.01.15 |
---|---|
89. 할인 행사 (0) | 2025.01.14 |
87. n^2 배열 자르기 (0) | 2025.01.12 |
86. H-Index (0) | 2025.01.11 |
85. 연속 부분 수열 합의 개수 (1) | 2025.01.08 |