HDU2546饭卡---(DP 经典背包)
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): 27001    Accepted Submission(s): 9430
某天,食堂中有n种菜出售,每种菜可购买一次。已知每种菜的价格以及卡上的余额,问最少可使卡上的余额为多少。
第一行为正整数n,表示菜的数量。n<=1000。
第二行包括n个正整数,表示每种菜的价格。价格不超过50。
第三行包括一个正整数m,表示卡上的余额。m<=1000。
n=0表示数据结束。
一个背包问题。就是提前需要一个预处理。。找到价格最高的饭菜,花费五元买去它。
然后就编程了n-1个物品,m-5元钱的背包问题。。
#include "cstdio"
#include "algorithm"
using namespace std;
#define N 1000+10
int price[N],dp[N][N];
int main()
{
int n,m;
while(~scanf("%d",&n)&&n)
{
int maxP=-,mark=-;
for(int i=;i<n;i++)
{
scanf("%d",&price[i]);
if(maxP<price[i]){
maxP=price[i];
mark=i;
}
}
price[mark]=;
scanf("%d",&m);
m-=;
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
{
dp[i][j]=i==?:dp[i-][j];
if(i>&&j>=price[i-])
dp[i][j]=max(dp[i-][j],dp[i-][j-price[i-]]+price[i-]);
}
}
int count=dp[n][m];
if(m>=)
printf("%d\n",m+-maxP-count);
if(m<)
printf("%d\n",m+);///不足5元的情况
}
return ;
}
HDU2546饭卡---(DP 经典背包)的更多相关文章
- [HDU2546]饭卡<dp  01背包>
		
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2546 #题目描述: 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前, ...
 - HDOJ(HDU).2546 饭卡(DP 01背包)
		
HDOJ(HDU).2546 饭卡(DP 01背包) 题意分析 首先要对钱数小于5的时候特别处理,直接输出0.若钱数大于5,所有菜按价格排序,背包容量为钱数-5,对除去价格最贵的所有菜做01背包.因为 ...
 - cdoj 31 饭卡(card) 01背包
		
饭卡(card) Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://acm.uestc.edu.cn/#/problem/show/31 Des ...
 - hdu 2546 饭卡 (01背包)
		
Problem Description 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前,卡上的剩余金额大于或等于5元,就一定可以购买成功(即使购买后卡上余额为负) ...
 - hdu 2546 饭卡【01背包】
		
题目链接:https://vjudge.net/contest/103424#problem/C 饭卡 Time Limit: 5000/ ...
 - HDU 2546 饭卡(0-1背包)
		
http://acm.hdu.edu.cn/showproblem.php?pid=2546 题意: 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前,卡上的剩余金 ...
 - HDU 2546:饭卡(01背包)
		
饭卡 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submiss ...
 - 题解报告:hdu 2546 饭卡(01背包)
		
Problem Description 电子科大本部食堂的饭卡有一种很诡异的设计,即在购买之前判断余额.如果购买一个商品之前,卡上的剩余金额大于或等于5元,就一定可以购买成功(即使购买后卡上余额为负) ...
 - HDU 2546 饭卡(01背包)
		
题目代号:HDU 2546 题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2546 饭卡 Time Limit: 5000/1000 MS (Java/ ...
 
随机推荐
- [【转】ubuntu 16.10 Server 安装及基本部署
			
一.Ubuntu Server 16.10 LTS 系统安装 Ubuntu 16.10 分为 桌面版 (desktop)和服务器版(Server).两者对于用户而言,最大的区别在于桌面版有图形操作界面 ...
 - 设计模式——模版方法模式详解(论沉迷LOL对学生的危害)
			
. 实例介绍 在本例中,我们使用一个常见的场景,我们每个人都上了很多年学,中学大学硕士,有的人天生就是个天才,中学毕业就会微积分,因此得了诺贝尔数学奖:也有的人在大学里学了很多东西,过得很充实很满意 ...
 - ajax设置自定义头
			
一.setting参数 headers $.ajax({ headers: { Accept: "application/json; charset=utf-8" ...
 - python语法join函数
			
Python语法中join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串. vid = )
 - python内置模块[re]
			
python内置模块[re] re模块: python的re模块(Regular Expression正则表达式)提供各种正则表达式的匹配操作,在文本解析.复杂字符串分析和信息提取时是一个非常有用的工 ...
 - 【C#】  语法糖
			
[C#] 语法糖 一, 扩展方法 1. 对某个类功能上的扩展 2. 特点: 使用方便,可以在不修改原代码的基础上进行扩展. 参照 linq,linq 就是一系列的扩展方法 3. 语法: 非泛型静态类, ...
 - Eclipse AmaterasUML 安装及使用
			
AmaterasUML 对于我来说,是一个非常好用的UML插件. 用它来将我写过的一些Android程序进行逆工程非常好用,只不过,不能体现出包,这是一个小小的遗憾. 这个是它的主页地址:http:/ ...
 - Selenium PageFactory页面工厂
			
使用Selenium PageFactory页面工厂的好处是: 当页面元素的位置发生变化时, 我们只需要去修改id或者xpath, 而不用去修改测试用例. import org.openqa.sele ...
 - 数据库学习(四)with as (补充 nvl 和 count 函数)
			
with as 的专业解释我这就不详细说明了,我这就梳理下我自己的实践应用,就是根据某个条件查询出结果集放在一个临时表里面,可以创建多个临时表,然后再从这些临时表中查询出要的数据. 参考资料:http ...
 - LeetCode 876——链表的中间结点
			
1. 题目 给定一个带有头结点 head 的非空单链表,返回链表的中间结点. 如果有两个中间结点,则返回第二个中间结点. 示例 1: 输入:[1,2,3,4,5] 输出:此列表中的结点 3 (序列化形 ...