洛谷P1091題解
阿新 • • 發佈:2020-11-01
原題:
思路:
讓求個序列
還得是中間高兩頭低的
還得是最長的
你說要是讓我求個最長增還行
最長減也可以,畢竟就是反向最長增
你要我求這個玩意??
不對,仔細一看,這不就是最長增和最長減拼在一起
從1-n求個最長增,再n-1求個最長增
再列舉“拼接點”,計算即可
程式碼:
#include <bits/stdc++.h> using namespace std; int n; int DT[105]; int DP[105]; int DP1[105]; int tmp1,tmp2; int main() { scanf("%d",&n); for(int i=1;i<=n;i++) { scanf("%d",&DT[i]); DP1[i]=1; DP[i]=1; } for(int i=1;i<=n;i++) { for(int j=1;j<i;j++) { if(DT[i]>DT[j]) DP[i]=max(DP[i],DP[j]+1); } } for(int i=n;i>=1;i--) {for(int j=n;j>i;j--) { if(DT[i]>DT[j]) DP1[i]=max(DP1[i],DP1[j]+1); } } for(int i=1;i<=n;i++) tmp1=max(tmp1,DP1[i]+DP[i]-1); printf("%d\n",n-tmp1); return 0; }