I 完美主义者
dp,最长子序列的衍生。
可参考经典题拦截导弹,那个是最长递增子序列。
代码:
#include <bits/stdc++.h>
using namespace std;
int inc1[200],inc2[200],a[200];
int main(){
int n;
while(scanf("%d",&n)!=EOF){
int ans=0,i,j;
for(i = 0; i < n; i++)scanf("%d",&a[i]);
//inc1[i]是存储以i为最高点时左边的递增子序列长度
inc1[0]=1;
for(i = 1; i < n; i++){
inc1[i] = 1;
for(j = 0; j < i; j++)
if(a[i] > a[j] && inc1[j] + 1 > inc1[i])
inc1[i] = inc1[j]+1;
}
//inc2[i]是存储以i为最高点时左边的递减子序列长度
inc2[n - 1] = 1;
for(i = n - 2; i >= 0; i--){
inc2[i] = 1;
for(j = n - 1; j > i; j--)
if(a[j] < a[i] && inc2[j] + 1 > inc2[i])
inc2[i] = inc2[j] + 1;
}
for(i = 0; i<=n; i++)
if(inc1[i] + inc2[i]-1 > ans)
ans = inc1[i] + inc2[i] - 1;//总长度为左右长度相加-1,因为多算了自己一次。
printf("%d\n",n-ans);
}
return 0;
}

京公网安备 11010502036488号