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

链接:click here~~

题意:

某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能超过前一发的高度.某天,雷达捕捉到敌国的导弹来袭.由于该系统还在试用阶段,所以只有一套系统,因此有可能不能拦截所有的导弹.

怎么办呢?多搞几套系统呗!你说说倒蛮容易,成本呢?成本是个大问题啊.所以俺就到这里来求救了,请帮助计算一下最少需要多少套拦截系统.

【解题思路】:

直接模拟一边就可以,不知道想简单了还是数据太弱,预处理之后,直接判断递减的导弹的数目,判断过的就标记0.

代码:

#include <stdio.h>
#include <string.h>
#include <algorithm>
#include<iostream>
using namespace std;
int main()
{
    int a[10000],n;
    while((scanf("%d",&n))!=EOF)
    {
        for (int i=0; i<n; i++) scanf("%d",&a[i]);
        int sum=0;
        for (int i=0; i<n; i++)
            if(a[i]){
                sum++;
                int h=a[i];
                for (int j=i+1; j<n; j++)
                    if (a[j]!=0&&h>=a[j])
                    {
                        h=a[j];
                        a[j]=0;
                    }
            }
        cout<<sum<<endl;
    }
    return 0;
}

HDU 2111

J - Saving HDU

链接:click here~~

题意:

多种宝贝,种类不少 ,每种宝贝单位体积的价格也不一样 计算出来XHD最多能带回多少价值的宝贝?(假设宝贝可以分割,分割后的价值和对应的体积成正比)

【解题思路】:贪心选取就可以了。。注意当前已经选取了价值最大的,剩下的不足以继续选,那么就直接乘以接下来的体积,然后记得一定要跳出循环!

代码:

#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn=105;
int n,m,t,i,j,s,num,ans;
struct node
{
    int val,V;
} p[maxn];
bool cmp(node a,node b)
{
    return a.val>b.val;
}
int main()
{
    int tot=1;
    while(~scanf("%d",&n)&&n)
    {
        scanf("%d",&m);
        for(i=0; i<m; i++)
            scanf("%d%d",&p[i].val,&p[i].V);
        sort(p,p+m,cmp);
        int s=0;
        for(i=0; i<m; i++)
        {
            if(n>p[i].V)
            {
                s+=p[i].val*p[i].V;
                n-=p[i].V;
            }
            else
            {
                s+=p[i].val*n;
                break;
            }
        }
        cout<<s<<endl;
    }
    return 0;
}
时间: 2024-10-13 11:52:34

【贪心专题】HDU 1257 最少拦截系统&&HDU 2111 Saving HDU (选宝贝)的相关文章

[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最少拦截系统(贪心)

最少拦截系统 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 最少拦截系统(贪心) 解题

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

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 最少拦截系统(贪心)

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

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 最少拦截系统 简单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 最少拦截系统【最长上升子序列】

解题思路:可以转化为求最长上升子序列来做,还是可以用an与按升序排列后的an求LCS来做,为防止超时,用滚动数组优化一下就可以了. 最少拦截系统 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 20625    Accepted Submission(s): 8174 Problem Description 某国为了防御敌国的导弹袭击,

Hdu 1257最少拦截系统

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