https://programmers.co.kr/learn/courses/30/lessons/12913
코딩테스트 연습 - 땅따먹기
땅따먹기 게임을 하려고 합니다. 땅따먹기 게임의 땅(land)은 총 N행 4열로 이루어져 있고, 모든 칸에는 점수가 쓰여 있습니다. 1행부터 땅을 밟으며 한 행씩 내려올 때, 각 행의 4칸 중 한 칸만 밟
programmers.co.kr
Level2 - 연습문제>
Q.
땅따먹기 게임을 하려고 합니다. 땅따먹기 게임의 땅(land)은 총 N행 4열로 이루어져 있고, 모든 칸에는 점수가 쓰여 있습니다. 1행부터 땅을 밟으며 한 행씩 내려올 때, 각 행의 4칸 중 한 칸만 밟으면서 내려와야 합니다.
단, 땅따먹기 게임에는 한 행씩 내려올 때, 같은 열을 연속해서 밟을 수 없는 특수 규칙이 있습니다.
예를 들면,
| 1 | 2 | 3 | 5 |
| 5 | 6 | 7 | 8 |
| 4 | 3 | 2 | 1 |
로 땅이 주어졌다면, 1행에서 네번째 칸 (5)를 밟았으면, 2행의 네번째 칸 (8)은 밟을 수 없습니다.
마지막 행까지 모두 내려왔을 때, 얻을 수 있는 점수의 최대값을 return하는 solution 함수를 완성해 주세요. 위 예의 경우, 1행의 네번째 칸 (5), 2행의 세번째 칸 (7), 3행의 첫번째 칸 (4) 땅을 밟아 16점이 최고점이 되므로 16을 return 하면 됩니다.
제한사항
- 행의 개수 N : 100,000 이하의 자연수
- 열의 개수는 4개이고, 땅(land)은 2차원 배열로 주어집니다.
- 점수 : 100 이하의 자연수
입출력 예
land | answer |
[[1,2,3,5],[5,6,7,8],[4,3,2,1]] | 16 |
A.
아마도 내 기억 속에서는 피보나치를 제외하고는 처음 만난 DP(Dynamic Programming), 즉 동적 계획법 문제 같다.
그래서 약간 어케 해야할지 감도 안 잡히고 겸사 제대로 공부 해보고자 구글링을 참고했다.
이 코드는 첫번째행부터 마지막행까지 순서대로 차차 내려가는 알고리즘이다.
첫번째 행은 그대로고 for문을 사용해서 두번째 행부터는 자신과 같은 열을 제외한 나머지 열들 중에서 가장 큰 수를 자기 자신에게 더한다. 그리고 그 새로운 값으로 자기 자신을 replace한다. 그렇게 쭉쭉 내려가면 맨 마지막 행에서는 각각 열들에서 최선을 다한 최대 합계값들로 각 열들이 리뉴얼되므로 그 중에서 가장 큰 수를 반환하면 된다.
이게 완료코드! 루프나 딴 걸 쓰면 세상 복잡해지고 무엇보다 모든 테케에서 런타임 에러가 뜬다.
않이 근데 저러케 DP를 사용해서 코딩해도 마지막에 최댓값 구할때 걍
int max = land[land.length-1][0]
for(int i=1; i<land.length; i++){
if(max<land[land.length-1][i]) max=land[land.length-1][i];
}
return max;
이렇게 하면 런타임에러가 뜬다....
그래서 걍 int배열 하나 만들어서 거기에 land[land.length-1]값들을 다 넣어주고 오름차순 정렬하고 마지막 return때, 그 int배열의 맨 마지막 값인 최대값을 return하는 것으로 했다~
'알고리즘 공부 > JAVA - 프로그래머스' 카테고리의 다른 글
[프로그래머스][JAVA][W12-#2] 없는 숫자 더하기 (0) | 2021.12.05 |
---|---|
[프로그래머스][JAVA][W12-#1] 다음 큰 숫자 (0) | 2021.12.05 |
[프로그래머스][JAVA][W11-#4] 이진 변환 반복하기 (0) | 2021.09.19 |
[프로그래머스][JAVA][W11-#3] 위장 (0) | 2021.09.19 |
[프로그래머스][JAVA][W11-#2] 숫자의 표현 (0) | 2021.09.19 |