[문제 설명]
(이런 문제의 경우, 손으로 직접 예제를 풀어보면서 문제를 이해하시는 게 제일 도움이 됩니다.)
문제에서 오른쪽 또는 아래쪽으로만 움직일 수 있고, 움직이면서 최대한 많이 산삼을 먹는게 목표인데요.
즉, 오른쪽 또는 아래쪽으로 이동해보면서 1을 가장 많이 지나는 경우를 찾으시면 됩니다.
[소스코드 설명]
저같은 경우 배열을 (1, 1)부터 사용을 하기 위해서 배열 사이즈를 하나 더 늘려주고, 처음에{0, 0}으로 초기화를 하였습니다. 이렇게 하시면은 비교를 할 때 맵의 크기를 넘어가는 경우에 대해서도 예외처리를 안해도 되기 때문에 매우 편합니다.
제가 짠 코드를 디버깅 돌려보면 다음과 같은 결과가 나옵니다.
0 |
1 |
2 |
3 |
4 |
5 |
|
0 |
0 |
0 |
0 |
0 |
0 |
0 |
1 |
0 |
0 |
1 |
1 |
1 |
2 |
2 |
0 |
0 |
1 |
2 |
2 |
2 |
3 |
0 |
1 |
1 |
3 |
4 |
4 |
4 |
0 |
2 |
3 |
3 |
5 |
5 |
5 |
0 |
3 |
3 |
3 |
5 |
6 |
'알고리즘 > 멤고리즘' 카테고리의 다른 글
멤고리즘 3회 2번. 색종이(피자) 쪼개기 (0) | 2014.04.22 |
---|---|
멤고리즘 3회 1번. 오목 (재귀) (0) | 2014.04.22 |
멤고리즘 2회 2번. 이진회귀수 (0) | 2014.04.22 |
멤고리즘 2회 1번. 거꾸로 말해요 (0) | 2014.04.22 |
멤고리즘 1회 3번. 복붙기능 키보드 (0) | 2014.04.22 |