标签:c++ 导弹拦截 mis pac its 空格 有一个 iss size
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 59285 Accepted Submission(s): 23248
题意:有一连串导弹,给出高度,拦截器每次拦截一次导弹,下次只能拦截不超过前一发高度的导弹,问最少需要多少拦截器
题解:就是求最少下降子序列,做法是每输入一个高度就和前面已经有的拦截器比较,如果能拦下就更新拦截器的高度,如果所有拦截器都比较过后都不能拦截,就新增加一个拦截器,并把当前高度赋给新增加的拦截器
1 #include<bits/stdc++.h> 2 using namespace std; 3 int dp[5000]; 4 int main() { 5 int n; 6 while(~scanf("%d",&n)) { 7 memset(dp,0,sizeof(dp)); 8 int j,m=0; 9 for(int i=0; i<n; i++) { 10 int temp; 11 scanf("%d",&temp); 12 for(j=1; j<=m; j++) { 13 if(temp<dp[j])//看前面的拦截器有没有高度比当前导弹低的,有就拦截 14 { 15 dp[j]=temp;break; 16 } 17 } 18 if(j>m)dp[++m]=temp;//j>m表示上面没有找到可以用的拦截器,需要新增加一个 19 } 20 printf("%d\n",m); 21 22 23 } 24 return 0; 25 }
标签:c++ 导弹拦截 mis pac its 空格 有一个 iss size
原文地址:https://www.cnblogs.com/fqfzs/p/9886709.html