문제 설명
2차원 행렬 arr1과 arr2를 입력받아, arr1에 arr2를 곱한 결과를 반환하는 함수, solution을 완성해주세요.
제한 조건- 행렬 arr1, arr2의 행과 열의 길이는 2 이상 100 이하입니다.
- 행렬 arr1, arr2의 원소는 -10 이상 20 이하인 자연수입니다.
- 곱할 수 있는 배열만 주어집니다.
[[1, 4], [3, 2], [4, 1]] | [[3, 3], [3, 3]] | [[15, 15], [15, 15], [15, 15]] |
[[2, 3, 2], [4, 2, 4], [3, 1, 4]] | [[5, 4, 3], [2, 4, 1], [3, 1, 1]] | [[22, 22, 11], [36, 28, 18], [29, 20, 14]] |
문제 풀이
행렬의 곱셈 공식을 그대로 적용해서 해결했습니다.
정답을 저장할 자료구조 2차원 배열을 미리 지정해놓고, 해당 2차원 배열에 더해지는 값을 누적해서 해결했습니다.
코드
function solution(arr1, arr2) {
const answer = new Array(arr1.length).fill(0).map(_=>new Array(arr2[0].length).fill(0));
const r1 = arr1.length;
const c1 = arr1[0].length;
const r2 = arr2.length;
const c2 = arr2[0].length;
for (let i=0; i<r1; i++) {
for (let j=0; j<c2; j++) {
for (let k=0; k<c1; k++) {
answer[i][j] += arr1[i][k] * arr2[k][j];
}
}
}
return answer
}
'Study > JavaScript' 카테고리의 다른 글
[JavaScript] Primitive(원시) 타입과 Reference(참조) 타입 (0) | 2024.06.23 |
---|