- 每次所浏览景点的编号都要大于前一个浏览景点的编号
- 不连续浏览海拔相同的两个景点,并且一旦开始下山,就不再向上走了
题目分析:
- 先登山后下山(不上山你怎么下山?)
- 登山:求(1~n)的最长上升子序列
- 下山:求(n~1)的最长上升子序列
- 总路长为s上山+s下山-1
代码如下:
#include<bits/stdc++.h>
using namespace std;
#define mm(a,x) memset(a,x,sizeof a)
#define mk make_pair
#define ll long long
#define pii pair<int,int>
#define inf 0x3f3f3f3f
#define lowbit(x) (x) & (-x)
const int N = 1010;
int t,n;
int a[N];
int f[N],g[N];
int main() {
cin >> n;
mm(a,0);mm(f,0);mm(g,0);
for(int i = 1; i <= n; i ++ ) cin >> a[i];
for(int i = 1; i <= n; i ++ ) {
f[i] = 1;
for(int j = 1; j < i; j ++ ) {
if(a[j] < a[i]) {
f[i] = max(f[i],f[j] + 1);
}
}
}
for(int i = n; i; i -- ) {
g[i] = 1;
for(int j = n; j > i; j -- ) {
if(a[j] < a[i]) {
g[i] = max(g[i],g[j] + 1);
}
}
}
int res = 0;
for(int i = 1; i <= n; i ++ ) res = max(res,f[i] + g[i] - 1);
cout<<res<<endl;
return 0;
}