中文的题目就不解释题意了,直接说思路
我用的是找出最长上升子序列的方法,因为在这个上升序列中的所有导弹都不能用同一个拦截系统,而且其余的导弹,都肯定能被和上升序列中 某一个相同的 拦截系统拦截,。
AC代码:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{
int n;
int a[1005],dp[1005];
while(scanf("%d",&n)!=EOF)
{
int maxx=1;
int j,i;
for(i=1;i<=n;i++)
cin>>a[i];
for(i=1;i<=n;i++)
{
dp[i]=1;
for(j=1;j<=i;j++)
{
if(a[j]<a[i])
{
dp[i]=max(dp[i],dp[j]+1);
}
}
maxx=max(dp[i],maxx);
}
cout<<maxx<<endl;
}
return 0;
}