본문 바로가기
알고리즘 공부/JAVA - 프로그래머스

[프로그래머스][JAVA][W11-#5] 땅따먹기

by hyoju1998 2021. 9. 19.

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하는 것으로 했다~