https://www.acmicpc.net/problem/2096
이 문제는 DP를 사용해서 해결할 수 있다.
문제에서 주어지는 가로의 길이는 항상 3이며, 세로의 길이는 N이다.
따라서 최소 DP와 최대 DP 배열을 만들고 배열의 크기는 3으로 한다.
항상 이전의 기록을 이용하기 때문에 입력을 받기 위한 크기 3의 배열이 필요하다.
#include <iostream>
using namespace std;
int N;
int score[3];
int minDp[3];
int maxDp[3];
int main(){
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin>>N;
int temp0, temp1, temp2;
for(int i = 0;i<N;i++){
cin>>score[0]>>score[1]>>score[2];
// 이전 정보 기록
temp0 = minDp[0];
temp1 = minDp[1];
temp2 = minDp[2];
// 최소 경로 계산
minDp[0] = min(temp0, temp1) + score[0];
minDp[1] = min(temp2, min(temp0, temp1)) + score[1];
minDp[2] = min(temp1, temp2) + score[2];
// 이전 정보 기록
temp0 = maxDp[0];
temp1 = maxDp[1];
temp2 = maxDp[2];
// 최대 경로 계산
maxDp[0] = max(temp0, temp1) + score[0];
maxDp[1] = max(temp2, max(temp0, temp1)) + score[1];
maxDp[2] = max(temp1, temp2) + score[2];
}
cout<<max(max(maxDp[0],maxDp[1]),maxDp[2])<<' ';
cout<<min(min(minDp[0],minDp[1]),minDp[2]);
}
'Baekjoon Review' 카테고리의 다른 글
[Gold 4] 14502 연구소 (0) | 2024.09.20 |
---|---|
[Gold 4] 12851 숨바꼭질 2 (0) | 2024.09.20 |
[Gold 4] 9935 문자열 폭발 (0) | 2024.09.16 |
[Gold 4] 10830 행렬 제곱 (0) | 2024.09.14 |
[Gold 5] 2447 별 찍기 - 10 (0) | 2024.09.14 |