-
题目描述:
-
某国为了防御敌国的导弹袭击,开发出一种导弹拦截系统。但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来袭,并观测到导弹依次飞来的高度,请计算这套系统最多能拦截多少导弹。拦截来袭导弹时,必须按来袭导弹袭击的时间顺序,不允许先拦截后面的导弹,再拦截前面的导弹。
-
输入:
-
每组输入有两行,第一行,输入雷达捕捉到的敌国导弹的数量k(k<=25),
第二行,输入k个正整数,表示k枚导弹的高度,按来袭导弹的袭击时间顺序给出,以空格分隔。
-
输出:
-
每组输出只有一行,包含一个整数,表示最多能拦截多少枚导弹。
-
样例输入:
-
8 300 207 155 300 299 170 158 65
-
样例输出:
-
6
-
#include <iostream> #include <cstdio> #include <cstring> #include <string> #include<cmath> #include <algorithm> using namespace std; #define inf 0x3f3f3f3f int a[30],b[30]; int main() { int i,j,s,n,t; scanf("%d",&t); while(t--) { scanf("%d",&n); for(i=0;i<n;i++) scanf("%d",&a[i]); b[0]=inf; s=0; for(i=0;i<n;i++) { for(j=s;j>=0;j--) if(b[j]>=a[i]) break;//严格递增去掉= b[j+1]=a[i]; if(j==s) s++; } printf("%d\n",s); } return 0; }
最长递增子序列
-
int LIS() { int i,j,l; memset(dp,0,sizeof(dp)); l=strlen(s); for(i=0;i<l;i++) { dp[i]=1; for(j=0;j<i;j++) { if(s[i]>s[j]&&dp[i]<1+dp[j]) dp[i]=1+dp[j]; } } mx=0; for(i=0;i<l;i++) if(mx<dp[i]) mx=dp[i]; return mx; }
最大连续子数组和
-
int MSA() { int i,cs=0,ms=a[0]; for(i=0;i<n;i++) { if(cs>=0) { cs+=a[i]; } else { cs=a[i]; } if(cs>ms) ms=cs; } return ms; }