hdu3466 Proud Merchants

大致题意:有n组数,每组数有三个数,pi,买这种物品你有的钱必须大于qi,你所能获得的价值vi。如果你想要买这种物品你所拥有的钱必须大于qi。

问你能用你所有的钱最多能获得多大价值。


解题思路:以第二组数据为例:A:5 10 5  B:3  5   6如果先买A的再买B的话需要花10块钱,但是先买B再买A的话需要13块钱。也就是花不同的钱却获得了相同的价值。所以这里排序就比较关键了!怎么排呢?还是以上面为例,先买A再买B花费p1+q2,先买B再买A花费p2+q1,p1+q2<p2+q1(为了使数据满足一定的顺序进行购买,因此我们使所有的数据都按照(q1-p1>q2-p2)这样的顺序排序,这样购买最终我们所需的钱数就是最少的,也就是拿同样多的钱,我们可以买更大价值的东西!在这里p1+q2<p2+q1与q1-p1>q2-p2等价,只不过在这里我们将描述同一个物体的变量放到不等式的一边(q1-p1>q2-p2),然后再进行排序操作比较方便罢了),如果我们都按照这样的顺序(qi-pi从大到小的顺序)进行排序,然而事实并非这样!!!请往下看(网上大神的解释......)

   其实01背包的购买都是按照从后向前的顺序进行购买的,也就是说,它的每次的最后一个商品是确定购买的,然后再加上前面的除下用的最后一个的钱之后能够够购买的最大的价值与不购买这个物品进行比较,哪个大就选哪个!(在这个过程中因为是先确定后面的物品是否购买,所以我们要将差值(qi-pi)大的放到后面,差值小的放到前面,也就是前面说的按照从大到小的顺序是进行购买的顺序,而真正排序,然后按照背包执行程序的时候是按照从小到大的顺序!)
          总之,就是按照差值(qi-pi)从小到大排序,然后用01背包的方法进行操作就行了!
Recently, iSea went to an ancient country. For such a long time, it was the most wealthy and powerful kingdom in the world. As a result, the people in this country are still very proud even if their nation hasn’t been so wealthy any more. 
The merchants were the most typical, each of them only sold exactly one item, the price was Pi, but they would refuse to make a trade with you if your money were less than Qi, and iSea evaluated every item a value Vi. 
If he had M units of money, what’s the maximum value iSea could get? 

Input
There are several test cases in the input. 

Each test case begin with two integers N, M (1 ≤ N ≤ 500, 1 ≤ M ≤ 5000), indicating the items’ number and the initial money. 
Then N lines follow, each line contains three numbers Pi, Qi and Vi (1 ≤ Pi ≤ Qi ≤ 100, 1 ≤ Vi ≤ 1000), their meaning is in the description. 

The input terminates by end of file marker. 

Output
For each test case, output one integer, indicating maximum value iSea could get. 

Sample Input
2 10
10 15 10
5 10 5
3 10
5 10 5
3 5 6
2 7 3
Sample Output
5
11
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
int n,m,p[1010],q[1010],v[1010],dp[1010][5010];
struct node
{
    int p,q,v;
} a[1010];
int cmp(node a,node b)
{
    return (a.q-a.p)<(b.q-b.p);
}
int main()
{
    int i,j;
    while(~scanf("%d%d",&n,&m))
    {
        memset(dp,0,sizeof(dp));
        for(i=1; i<=n; i++)
        {
            scanf("%d%d%d",&a[i].p,&a[i].q,&a[i].v);
        }
        sort(a+1,a+n+1,cmp);//按照差价从小到大排序
        for(i=1; i<=n; i++)
        {
            for(j=0; j<=m; j++)
            {
                dp[i+1][j]=dp[i][j];
                if(j>=a[i].q)//只有大于去a[i].q才能购买
                {
                    dp[i+1][j]=max(dp[i][j],dp[i][j-a[i].p]+a[i].v);
                }
            }
        }
        printf("%d\n",dp[n+1][m]);
    }
    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本系统的研发具有重大的意义,在安全性方面,用户使用浏览器访问网站时,采用注册和密码等相关的保护措施,提高系统的可靠性,维护用户的个人信息和财产的安全。在方便性方面,促进了校园失物招领网站的信息化建设,极大的方便了相关的工作人员对校园失物招领网站信息进行管理。 本系统主要通过使用Java语言编码设计系统功能,MySQL数据库管理数据,AJAX技术设计简洁的、友好的网址页面,然后在IDEA开发平台中,编写相关的Java代码文件,接着通过连接语言完成与数据库的搭建工作,再通过平台提供的Tomcat插件完成信息的交互,最后在浏览器中打开系统网址便可使用本系统。本系统的使用角色可以被分为用户和管理员,用户具有注册、查看信息、留言信息等功能,管理员具有修改用户信息,发布寻物启事等功能。 管理员可以选择任一浏览器打开网址,输入信息无误后,以管理员的身份行使相关的管理权限。管理员可以通过选择失物招领管理,管理相关的失物招领信息记录,比如进行查看失物招领信息标题,修改失物招领信息来源等操作。管理员可以通过选择公告管理,管理相关的公告信息记录,比如进行查看公告详情,删除错误的公告信息,发布公告等操作。管理员可以通过选择公告类型管理,管理相关的公告类型信息,比如查看所有公告类型,删除无用公告类型,修改公告类型,添加公告类型等操作。寻物启事管理页面,此页面提供给管理员的功能有:新增寻物启事,修改寻物启事,删除寻物启事。物品类型管理页面,此页面提供给管理员的功能有:新增物品类型,修改物品类型,删除物品类型。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值