본문 바로가기
프로그래머스/JAVA

[level 2] 행렬의 곱셈

by AsCE_hyunseung 2018. 9. 11.
1
2
3
4
5
6
7
8
9
10
11
12
13
class Solution {
    public int[][] solution(int[][] arr1, int[][] arr2) {
        int[][] answer = new int[arr1.length][arr2[0].length];//결과 행렬의 크기는 arr1의 행의 크기와 arr2의 열의 크기로 나온다
        for (int i = 0; i < answer.length; i++) {
            for (int j = 0; j < answer[0].length; j++) {
                for (int k = 0; k < arr1[0].length; k++) {
                    answer[i][j] += arr1[i][k] * arr2[k][j];
                }
            }
        }
        return answer;
    }
}
cs


- 문제 설명

2차원 행렬 arr1과 arr2를 입력받아, arr1에 arr2를 곱한 결과를 반환하는 함수, solution을 완성해주세요.


- 제한 조건

행렬 arr1, arr2의 행과 열의 길이는 2 이상 100 이하입니다.

행렬 arr1, arr2의 원소는 -10 이상 20 이하인 자연수입니다.

곱할 수 있는 배열만 주어집니다.


반복 제어 변수인 i,j,k를 쓰면 가독성이 안좋아보여서 의미있는 이름을 쓰고 싶었는데 생각이 잘 안났다(..)

단순히 알고리즘만 본다면 레벨1에 속했을 것 같은데 3중 반복문이 들어가서 레벨2 문제에 속한 것 같다.

이 문제도 TDD방법론으로 풀려고 junit을 import하고 assertEqual을 써서 테스트 해보려고 했는데 의존성 주입(?)이라는 새로운 난제 때문에 힘들었다.

어째 저째 구글링을 통해서 문제 해결을하고 단위 테스트를 위해 비교하려고 하는데 배열이름을 비교하면 자바에서는 주소값 비교가 된다...Aㅏ...

그래서 이번 문제는 print()를 이용해서 단위 테스트를 했다(...) 다음 문제부터는 배열 비교를 하는 메소드를 만들어야겠다.

'프로그래머스 > JAVA' 카테고리의 다른 글

[정렬] K번째수  (0) 2018.09.21
[level 2] N개의 최소공배수  (0) 2018.09.13
[level 2] 다음 큰 숫자  (0) 2018.09.10
[level 1] 핸드폰 번호 가리기  (0) 2018.09.06
[level 1] 정수 제곱근 판별  (0) 2018.09.04