1. 程式人生 > 實用技巧 >洛谷P1091題解

洛谷P1091題解

原題:

思路:

讓求個序列

還得是中間高兩頭低的

還得是最長的

你說要是讓我求個最長增還行

最長減也可以,畢竟就是反向最長增

你要我求這個玩意??

不對,仔細一看,這不就是最長增和最長減拼在一起

從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; }