求以a[i]为结束结点时的最长上升序列长度,保存在d1[i]中,从前向后更新
再求 a[i]为开始结点时最长下降序列长度,保存在d2[i]中,从后向前更新
#include<stdio.h>
int a[102],d1[102],d2[102];
int main()
{
int n,i,j,max;
while(scanf("%d",&n)!=EOF)
{
for(i=0;i<n;i++)
scanf("%d",&a[i]);
d1[0]=1;
for(i=1;i<n;i++)
{
d1[i]=1;
for(j=0;j<i;j++)
if(a[j]<a[i]&&d1[j]+1>d1[i])
d1[i]=d1[j]+1;
}
d2[n-1]=1;
for(i=n-2;i>=0;i--)//更新以a[i]为开始结点,一直到序列尾最长下降序列长度
{
d2[i]=1;
for(j=n-1;j>i;j--)
if(a[j]<a[i]&&d2[j]+1>d2[i])
d2[i]=d2[j]+1;
}
for(i=0;i<n;i++)
d1[i]=d1[i]+d2[i]-1;
max=d1[0];
for(i=1;i<n;i++)
if(max<d1[i]) max=d1[i];
printf("%d\n",n-max);
}
return 0;
}