HDU 1257(最小拦截系统)

Description

某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不 能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.
怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.

Input

输入若干组数据.每组数据包括:导弹总个数(正整数),导弹依此飞来的高度(雷达给出的高度数据是不大于30000的正整数,用空格分隔)

Output

对应每组数据输出拦截所有导弹最少要配备多少套这种导弹拦截系统.

Sample Input

8 389 207 155 300 299 170 158 65

Sample Output

2

数据小,水过,

求最小的递减序列个数 ,把递减的给标记,不过是二维数组标记,因为有一样的高度,怕重复

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cmath>
 4 #include<cstring>
 5 using namespace std;
 6 int main()
 7 {
 8     int n;
 9     int a[1009];
10     short visited[1009][1009];
11     int i,j,t;
12     while(cin>>n)
13     {
14         for(i=1;i<=n;i++)
15             cin>>a[i];
16         int ans=0;
17         memset(visited,0,sizeof(visited));
18         for(i=1;i<=n;i++)
19         {
20             int sum=0;
21             t=30001;
22             for(j=1;j<=n;j++)
23             {
24                 if(t>=a[j]&&visited[j][a[j]]==0)
25                 {
26                     visited[j][a[j]]=1;
27                     t=a[j];
28                     sum++;
29                 }
30             }
31             if(sum>0)
32                 ans++;
33
34         }
35         cout<<ans<<endl;
36     }
37 }
时间: 2024-11-01 21:41:13

HDU 1257(最小拦截系统)的相关文章

[2016-03-27][HDU][1257][最少拦截系统]

时间:2016-03-27 14:51:35 星期日 题目编号:[2016-03-27][HDU][1257][最少拦截系统] 分析:贪心,每当不能拦截就增加一个拦截系统,可以发现,每个拦截系统拦截的高度比较和出现的顺序一样.即第二个系统始终比第一个系统拦截的高度高 #include <cstdio> using namespace std; int a[30000 + 10]; int main(){ int n,b,flg; while(~scanf("%d",&

HDU 1257 最少拦截系统

http://acm.hdu.edu.cn/showproblem.php? pid=1257 题目大意: 有一种导弹拦截系统,每次仅仅能发射比前一发导弹低的炮弹,给定一些导弹的突击顺序,求至少须要多少导弹拦截系统来全然阻止 思路: 好久没做题.做题水的~ 直接模拟就可以~ #include<cstdio> const int MAXN = 30000 + 10; const int INF = 0x3ffffff; int a[MAXN], ans; int cur_max[MAXN]; /

HDU 1257 最少拦截系统 简单DP

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1257 题目大意:求有多少个单调非递增序列. 解题思路:经典题的变形----LIS.可以按照题意,多次dp,每次记录路径并进行访问标记,每次dp只要有更新过就++ans. 然而稍微思考就发现实际上求得就是最长单调递增序列的长度. 代码: const int maxn = 1e6 + 5; int n, a[maxn]; int dp[maxn]; void solve(){ memset(dp, 0,

HDU 1257——最少拦截系统——————【LIS变型题】

最少拦截系统 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Status Practice HDU 1257 Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有

HDU 1257 最少拦截系统(Dilworth定理+LIS)

最少拦截系统 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 35053    Accepted Submission(s): 13880 Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的

HDU 1257 最少拦截系统【LIS】

题意:类似于套娃娃,问最少需要多少个拦截系统. 思路: 假设已经有m个导弹拦截序列 r1:x11>=x12>=x13>=...>=x1n r1:x21>=x22>=x23>=...>=x2n. . rm:xm1>=xm2>=xm3>=...>=xmn 则必定有有一个序列x1i<x2i<x3i<...<xmi,证明: 若rx中最小比他后边某个序列的所有元素都要大的话,这两个序列必定能合成一个序列. 如r1:8,5

hdu 1257最少拦截系统(贪心)

最少拦截系统 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 23724    Accepted Submission(s): 9303 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1257 Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是

题解报告:hdu 1257 最少拦截系统

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1257 解题思路:题目的关键句是"第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度."这句话的意思就是给你一组数据,从头到尾选出需要拦截系统的高度(较小值),做法是依次保存现在每个拦截系统能拦截的最高的高度,接下来输入的每一个高度,依次和这若干拦截系统的现在所能拦截的最高高度进行比较,若某次小于这个高度,就替代这个高度,(并直接退出当前循环):若比这些拦截系统的高度都高

hdu 1257 最少拦截系统 (贪心)

最少拦截系统 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 20766 Accepted Submission(s): 8213 Problem Description 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷

【贪心专题】HDU 1257 最少拦截系统&amp;&amp;HDU 2111 Saving HDU (选宝贝)

链接:click here~~ 题意: 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹. 怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统. [解题思路]: 直接模拟一边就可以,不知道想简单了还是数据