반응형
프로그래머스의 알고리즘 문제 및 풀이에 대해 차근차근 포스팅하려합니다.
저도 초보자이기도하고 알고리즘에 쉽게 다가갈 수 없는 부분들이 많기 때문에
최대한 알기 쉽게 정리해보려하고 알고리즘을 어려워하는 분들에게 도움이 되었으면 합니다.
많이 공유되고 토론이 될 수 있는 공간이 되었으면 좋겠습니다.
환경
언어 : 자바
단계 : 레벨 1단계 (입문자용)
정답률 : 78%
제목
행렬의 덧셈
문제 설명 및 코드
행렬의 덧셈은 행과 열의 크기가 같은 두 행렬의 같은 행, 같은 열의 값을 서로 더한 결과가 됩니다. 2개의 행렬 arr1과 arr2를 입력받아, 행렬 덧셈의 결과를 반환하는 함수, solution을 완성해주세요.
- 행렬 arr1, arr2의 행과 열의 길이는 500을 넘지 않습니다.
1
2
3
4
5
6
|
class Solution {
public int[][] solution(int[][] arr1, int[][] arr2) {
int[][] answer = {};
return answer;
}
}
|
cs |
입출력 예
arr1 | arr2 | return |
[[1,2],[2,3]] | [[3,4],[5,6]] | [[4,6],[7,9]] |
[[1],[2]] | [[3],[4]] | [[4],[6]] |
반응형
문제 정답 코드
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][arr1[0].length];
for(int a=0; a<arr1.length; a++){
for(int s=0; s<arr1[0].length; s++){
answer[a][s] = arr1[a][s] + arr2[a][s];
}
}
return answer;
}
}
|
cs |
조건이 행과 열의 크기가 같은 배열이므로
우선 answer를 배열의 전체길이와 열의 크기로 초기화하고
이중 반복문으로 각각의 숫자를 더해서 반환하였습니다.
다른사람 풀이
1
2
3
4
5
6
7
8
9
10
11
12
|
class Solution {
public int[][] solution(int[][] arr1, int[][] arr2) {
int[][] answer = {};
answer = arr1;
for(int i=0; i<arr1.length; i++){
for(int j=0; j<arr1[0].length; j++){
answer[i][j] += arr2[i][j];
}
}
return answer;
}
}
|
cs |
전반적으로 저의 코드와 비슷하지만
초기화시킬때 answer에 arr1를 대입하여 초기화하여 바로 arr2와 더해주었습니다.
반응형
'Algorithm' 카테고리의 다른 글
[Java&알고리즘] 3진법 뒤집기 (Level 1) (0) | 2023.04.06 |
---|---|
[Java&알고리즘] 같은 숫자는 싫어 (Level 1) (0) | 2023.04.04 |
[Java&알고리즘] 부족한 금액 계산하기 (Level 1) (0) | 2023.03.29 |
[Java&알고리즘] 문자열 다루기 기본 (Level 1) (0) | 2023.03.29 |
[Java&알고리즘] 약수의 개수와 덧셈 (Level 1) (0) | 2023.03.28 |
댓글