[Programmers] 43105번 - 정수 삼각형 [Java][C++]
[Programmers] 43105번 - 정수 삼각형 [Java][C++]
1. 문제 풀이
정수 삼각형에서 특정 위치까지 내려왔을 때 선택된 수의 합의 최댓값은 바로 윗 층의 왼쪽 대각선까지 올 때 선택할 수 있었던 수의 합과 오른쪽 대각선까지 올 때 선택할 수 있었던 수의 합 중 더 큰 값에서 현재 위치를 선택하면 된다. 따라서 다이나믹 프로그래밍을 활용해 해결할 수 있다. 가장 마지막 층에서 어떤 칸이 최댓값인지 알 수 없으므로 한 번 쭉 탐색하며 최댓값을 찾아주면 된다.
2. 코드
1. 풀이 [Java]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
class Solution {
public int solution(int[][] triangle) {
int len = triangle.length;
int[][] dp = new int[1 + len][1 + len];
for (int i = 1; i <= len; i++) {
for (int j = 1; j <= i; j++) {
dp[i][j] = Math.max(dp[i - 1][j - 1], dp[i - 1][j]) + triangle[i - 1][j - 1];
}
}
int ans = 0;
for (int i = 1; i <= len; i++) {
ans = Math.max(ans, dp[len][i]);
}
return ans;
}
}
2. 풀이 [C++]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <algorithm>
#include <string>
#include <vector>
using namespace std;
int solution(vector<vector<int>> triangle) {
int len = triangle.size();
vector<vector<int>> dp(1 + len, vector<int>(1 + len));
for (int i = 1; i <= len; i++) {
for (int j = 1; j <= i; j++) {
dp[i][j] = max(dp[i - 1][j - 1], dp[i - 1][j]) + triangle[i - 1][j - 1];
}
}
return *max_element(dp[len].begin(), dp[len].end());
}
This post is licensed under CC BY 4.0 by the author.