티스토리 뷰
문제 : boj 11052
풀이
- DP 문제
- 배열 _sum[n]은 n개 카드 구매시 최대값이다.
- 배열 _sum의 값을 이용해 구매 카드 수가 n개일 때, (n-1장 구매시 최대값 + 1장 구매가격),(n-2장 구매시 최대값 + 2장 구매가격),...,(n장구매가격)을 비교해 최대값을 _sum[n]에 넣는다.
C++
#include <iostream>
#include <cstdio>
using namespace std;
int N, price\[1001\];
unsigned int \_sum\[1002\];
void dp(int n){
unsigned int \_max(0);
if(n == 1) {
\_sum\[1\] = price\[0\];
dp(n+1);
return;
}
else if(n == N+1) return;
for (int i(1); i < n; i++){
unsigned int tmp = \_sum\[n-i\]+\_sum\[i\];
if(tmp > \_max) \_max = tmp;
}
if (\_max < price\[n-1\]) \_max = price\[n-1\];
\_sum\[n\] = \_max;
dp(n+1);
}
int main(){
freopen("input.txt","r", stdin);
cin >> N;
for (int i(0); i < N; i++){
cin >> price\[i\];
}
dp(1);
cout << \_sum\[N\];
fclose(stdin);
return 0;
}
'algorithm' 카테고리의 다른 글
BOJ2206: 벽 부수고 이동하기 (0) | 2021.12.04 |
---|
댓글
최근에 올라온 글
TAG
- 운영체제
- pcb
- Operating System
- ML Pipeline
- OS
- mode collapse
- deeplearning
- depth
- Generative Model
- depthmap
- Deep learning
- AI
- Building Basic GAN
- Depth estimation
- TRACKING
- machine learning
- ML
- 3d object detection
- image
- Raspberry Pi
- feature
- MLOps
- controllable GAN
- conditional GAN
- 딥러닝
- 디지털신호처리
- 신호처리
- DSP
- design pattern
- Gan
- Total
- Today
- Yesterday
최근에 달린 댓글
링크
공지사항
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
글 보관함