饭卡------HDOJ杭电2546(还是01背包!!!!!!)

Problem Description

电子科大本部食堂的饭卡有一种非常诡异的设计,即在购买之前推断剩余金额。

假设购买一个商品之前,卡上的剩余金额大于或等于5元,就一定能够购买成功(即使购买后卡上剩余金额为负),否则无法购买(即使金额足够)。所以大家都希望尽量使卡上的剩余金额最少。

某天,食堂中有n种菜出售。每种菜可购买一次。

已知每种菜的价格以及卡上的剩余金额,问最少可使卡上的剩余金额为多少。

Input

多组数据。对于每组数据:

第一行为正整数n。表示菜的数量。n<=1000。

第二行包含n个正整数。表示每种菜的价格。价格不超过50。

第三行包含一个正整数m,表示卡上的剩余金额。m<=1000。

n=0表示数据结束。

Output

对于每组输入,输出一行,包括一个整数。表示卡上可能的最小剩余金额。

Sample Input

1
50
5
10
1 2 3 2 1 1 2 3 2 1
50
0

Sample Output

-45
32

这道题吧,怎么说呢?比起那个骨头那题是有点处理数据的技巧,只是也没什么,以下就来分析一下:

我们先把数据排序,找到最大的那个数maxn,作为来减的数,sort还有什么的即可了。m作为饭卡剩余金额,由于题目以5为分界线,所以m-=5。

然后就是我们最最主要的01背包啦。!

!!!

for(i=1;i<n;i++)
        {
            for(j=m;j>=price[i];j--)
            {
                dp[j]=max(dp[j],dp[j-price[i]]+price[i]);
            }
        }

这里dp[m]存储的是能减到最接近5,但是又大于等于5的数,然后输出这样写即可了:

printf("%d\n",m+5-dp[m]-maxn);

嗯,大概就是这样。主要就是那个循环,理解然后运用即可了!

!!!。!

语言描写叙述可能不是非常清晰,大伙凑合看吧;

以下贴下AC代码:

#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
int main()
{
    int i,j,k;
    int t,n,m;
    int maxn;
    int dp[2014]={0},price[2014]={0};
    while(scanf("%d",&n)!=EOF,n)
    {
        memset(price,0,sizeof(price));
        memset(dp,0,sizeof(dp));
        for(i=1;i<=n;i++)
        {
            cin>>price[i];
        }
        cin>>m;
        if(m<5)
        {
            printf("%d\n",m);
            continue;
        }
        sort(price+1,price+n+1);
        maxn=price[n];
        m=m-5;
        for(i=1;i<n;i++)
        {
            for(j=m;j>=price[i];j--)
            {
                dp[j]=max(dp[j],dp[j-price[i]]+price[i]);
            }
        }
        printf("%d\n",m+5-dp[m]-maxn);
    }
    return 0;
}

写代码能力有限,如有编程爱好者发现BUG。还请指出,不胜感激!

!。!

时间: 2024-10-06 22:04:35

饭卡------HDOJ杭电2546(还是01背包!!!!!!)的相关文章

杭电 2546 饭卡(01背包)

http://acm.hdu.edu.cn/showproblem.php?pid=2546 饭卡 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 11285    Accepted Submission(s): 3880 Problem Description 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一

魔咒词典------HDOJ杭电1880(字符串的处理,很简单)

Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一个需要的魔咒,所以他需要你的帮助. 给你一部魔咒词典.当哈利听到一个魔咒时,你的程序必须告诉他那个魔咒的功能:当哈利需要某个功能但不知道该用什么魔咒时,你的程序要替他找到相应的魔咒.如果他要的魔咒不在词典中,就输出"what?" Input 首先列出词典中不超过100000条不同的魔咒词条,每条格式

Is It A Tree?------HDOJ杭电1325(两种方法,可以用也可以不用并查集!!!!!!详解)

Problem Description A tree is a well-known data structure that is either empty (null, void, nothing) or is a set of one or more nodes connected by directed edges between nodes satisfying the following properties. There is exactly one node, called the

杭电 2546 饭卡【01背包】

解题思路:先忽略饭卡余额大于等于5块才能买饭这一细节,需要求的是饭卡里面剩余的钱最少,转化一下,变成花的钱最多,那么剩下的钱就最少,再考虑余额大于等于5块才能买饭这一细节,可以这样想,如果卡里的余额不足5块,那么买不到饭,直接输出现在卡里的金额,如果卡里的钱多于5块,我们就可以先将这5块钱留起来,这样保证它每一次买饭卡里的余额都是大于5块的,最后卡里剩下的5块钱则用来买最贵的菜,这样就需要对菜的价钱进行排序.经过这样的转化后就可以转化成一个容量为m-5的包怎样装获得最大价值的01背包问题了. 反

杭电 2546 饭卡

Problem Description 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前,卡上的剩余金额大于或等于5元,就一定可以购买成功(即使购买后卡上余额为负),否则无法购买(即使金额足够).所以大家都希望尽量使卡上的余额最少.某天,食堂中有n种菜出售,每种菜可购买一次.已知每种菜的价格以及卡上的余额,问最少可使卡上的余额为多少. Input 多组数据.对于每组数据:第一行为正整数n,表示菜的数量.n<=1000.第二行包括n个正整数,表示每种菜的价格.价

IP的计算------HDOJ杭电2206(写完脑洞大开,想象力要足够丰富)

Problem Description 在网络课程上,我学到了很多有关IP的知识.IP全称叫网际协议,有时我们又用IP来指代我们的IP网络地址,现在IPV4下用一个32位无符号整数来表示,一般用点分方式来显示,点将IP地址分成4个部分,每个部分为8位,表示成一个无符号整数(因此不需要用正号出现),如192.168.100.16,是我们非常熟悉的IP地址,一个IP地址串中没有空格出现(因为要表示成一个32数字). 但是粗心的我,常常将IP地址写错,现在需要你用程序来判断. Input 输入有多个c

hdoj 2602 Bone Collector 【01背包】

意甲冠军:给出的数量和袋骨骼的数,然后给每块骨骼的价格值和音量.寻求袋最多可容纳骨骼价格值 难度;这个问题是最基本的01背包称号,不知道的话,推荐看<背包9说话> AC by SWS 主题链接 http://acm.hdu.edu.cn/showproblem.php?pid=2602 代码: #include<stdio.h> #include<string.h> typedef struct{ int w, v; }str; str s[1005]; int dp[

HDOJ 2602 Bone Collector【01背包】

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2602 Bone Collector Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 34251    Accepted Submission(s): 14101 Problem Description Many years ago , in

杭电 oj2602~(0-1背包问题)

Bone Collector Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 51417    Accepted Submission(s): 21634 Problem Description Many years ago , in Teddy’s hometown there was a man who was called “Bon