[BOJ] 11054 가장 긴 바이토닉 부분 수열

Time Lapse :12min 7sec

11054.c

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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#include <stdio.h>
#include <memory.h>
int val[1000];
int dp[1000][3];
int N;
int max(int a, int b){
return a>b?a:b;
}
int f(int c,int dir){
if(dp[c][dir]!=-1) return dp[c][dir];
int leftmax = 0, rightmax = 0;
dp[c][dir] = 0;
switch(dir){
case 0 :
for (int i = 0; i < c; ++i) {
if(val[i]>=val[c]) continue;
leftmax = max(leftmax, f(i, 1));
}
for(int i = c+1; i < N; ++i) {
if(val[i]>=val[c]) continue;
rightmax = max(rightmax, f(i, 2));
}
break;
case 1 :
for (int i = 0; i < c; ++i) {
if(val[i]>=val[c]) continue;
leftmax = max(leftmax, f(i, 1));
}
break;
case 2:
for(int i = c+1; i < N; ++i) {
if(val[i]>=val[c]) continue;
rightmax = max(rightmax, f(i, 2));
}
break;
}
dp[c][dir] = leftmax + rightmax + 1;
return dp[c][dir];
}
int main() {
scanf("%d",&N);
for(int i = 0; i < N; ++i)
scanf("%d",&val[i]);
memset(dp,-1,sizeof(dp));
int ans = 0;
for(int i = 0; i < N; ++i)
ans = max(ans, f(i,0));
printf("%d",ans);
}
Author: Song Hayoung
Link: https://songhayoung.github.io/2020/07/23/PS/BOJ/11054/
Copyright Notice: All articles in this blog are licensed under CC BY-NC-SA 4.0 unless stating additionally.