首页 > 其他 > 详细

HDU-5188zhx and contest(贪心+背包)

时间:2020-07-07 23:00:57      阅读:87      评论:0      收藏:0      [点我收藏+]

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5188

题目大意:打比赛得积分,有n个题,要求达到w分,求最短时间,每个题有消耗时间t,得分v,以及一个限制l(完成该题的时间不能在l前面).

emmm,这个需要贪心配合背包,我们知道的是,如果他写1道题目要2分钟,但限制为4分钟,那么这多余的2分钟就会被浪费掉,所以我们必须先选择充分利用时间的,也就是$l-t$越小的越优。

排完序然后就是跑01背包了,自己定义一个时间时间上限作为背包容量即可跑板子了

以下是AC代码:

#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;

const int mac=1e5+10;

long long dp[mac*30];
struct node
{
    int t,v,l;
    bool operator<(const node&a)const {
        return l-t<a.l-a.t;//越充分利用时间越优,浪费时间的后选
    }
}a[50];

int main()
{
    int n,w;
    while (~scanf ("%d%d",&n,&w)){
        memset(dp,0,sizeof dp);
        int s=0,ss=0;
        for (int i=0; i<50; i++)
            a[i].t=a[i].v=a[i].l=0;
        long long pt=0;
        for (int i=1; i<=n; i++){
            int t,v,l;
            scanf ("%d%d%d",&t,&v,&l);
            a[i]=node{t,v,l};
            pt+=v;
            s+=a[i].t;ss=max(a[i].l,ss);
        }
        if (pt<w) {printf("zhx is naive!\n"); continue;}
        int tot=max(s,ss)+10;
        sort(a+1,a+1+n);
        for (int i=1; i<=n; i++){
            for (int j=tot; j>=max(a[i].t,a[i].l); j--){
                dp[j]=max(dp[j],dp[j-a[i].t]+a[i].v);
            }
        }
        for (int i=0; i<=tot; i++)
            if (dp[i]>=w) {
                printf("%d\n",i);
                break;
            }
    }

    return 0;
}

 

HDU-5188zhx and contest(贪心+背包)

原文:https://www.cnblogs.com/lonely-wind-/p/13263584.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!