悼念512汶川大地震遇难同胞——珍惜现在,感恩生活
Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 4215 Accepted Submission(s): 1690
Problem Description
急!灾区的食物依然短缺!
为了挽救灾区同胞的生命,心系灾区同胞的你准备自己采购一些粮食支援灾区,现在假设你一共有资金n元,而市场有m种大米,每种大米都是袋装产品,其价格不等,并且只能整袋购买。
请问:你用有限的资金最多能采购多少公斤粮食呢?
Input
输入数据首先包含一个正整数C,表示有C组测试用例,每组测试用例的第一行是两个整数n和m(1<=n<=100, 1<=m<=100),分别表示经费的金额和大米的种类,然后是m行数据,每行包含3个数p,h和c(1<=p<=20,1<=h<=200,1<=c<=20),分别表示每袋的价格、每袋的重量以及对应种类大米的袋数。
Output
对于每组测试数据,请输出能够购买大米的最多重量,你可以假设经费买不光所有的大米,并且经费你可以不用完。每个实例的输出占一行。
Sample Input
Sample Output
此题是最简单的多重背包,数据小的话直接转化成01背包来解。
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2191
代码:
#include <iostream>
#include <stdio.h>
#include <memory.h>
using namespace std;
int c[105], w[105], n[105];
int bag[105];
int N, V;
void _mul_bag() //多重背包:直接转换成01背包(数据比较小)
{
int i, j, k;
memset(bag, 0, sizeof(bag));
for(i = 0; i < N; i++)
{
for(k = 1; k <= n[i]; k++)
{
for(j = V; j >= c[i]; j--)
{
bag[j] = max(bag[j], bag[j-c[i]] + w[i]);
}
}
}
}
int main()
{
int i, t;
scanf("%d", &t);
while(t--)
{
scanf("%d %d", &V, &N);
for(i = 0; i < N; i++)
scanf("%d %d %d", &c[i], &w[i], &n[i]);
_mul_bag();
printf("%d\n", bag[V]);
}
return 0;
}
分享到:
相关推荐
背包问题模板 hdu2191 背包问题是计算机科学中一种经典的NP完全问题,它是指给定一个容量为V的背包和N种物品,每种物品具有价值和重量,如何选择物品放入背包,使得总价值最大化且总重量不超过背包容量。背包问题有...
1. "2013暑期多校联合训练第一场0723-解题报告.pdf":这个PDF文件包含了这次训练的解题报告,可能包括了所有题目及其解法的详细分析,对于参赛者来说,这是理解和学习解题策略的重要资源。 2. "2013暑期多校联合训练...
杭电ACM课件2014版之 (HDUACM201303版_07)背包专题
压缩包内的文件名“朝花夕拾——hdu”可能表示这是一系列关于HDU题目的代码记录,"朝花夕拾"是一个成语,意味着回忆过去的事情,这里可能是暗示这些代码是作者在过去解决HDU题目时留下的,现在整理出来分享或复习。...
【标题】"HDU_2010.rar"是一个压缩包文件,其中包含了与"HDU 2010"相关的资源,特别是针对"HDU ACM20"比赛的编程题目。"hdu 2010"和"hdu 20"可能是该比赛的不同简称或分类,而"hdu acm20"可能指的是该赛事的第20届...
例如,一个简单的动态规划问题可以是“斐波那契数列”,其中状态通常定义为第n个斐波那契数,状态转移方程为F(n) = F(n-1) + F(n-2),初始条件为F(0) = 0,F(1) = 1。 在HDU的DP题目中,可能会有各种复杂度的题目,...
HDU是一个知名的在线编程竞赛平台,它提供了大量的算法题目供参赛者练习和提交解决方案。这里的“java实现”意味着作者使用Java作为编程工具来解答这些算法题。 在Java编程方面,以下是一些可能涵盖的知识点: 1. ...
【标题】:“hdu2191NBag.rar”是一个关于数学计算和Visual C++编程的资源包,其中包含了杭州电子科技大学ACM(国际大学生程序设计竞赛)评价系统的第2191题“多重背包”的解决方案。这个题目是算法竞赛中常见的问题...
【标题】"hdu.rar_HDU 1089.cpp_OJ题求和_hdu_horsekw5_杭电obj" 提供的信息是关于一个压缩文件,其中包含了一个名为 "HDU 1089.cpp" 的源代码文件,这个文件是为了解决杭州电子科技大学(Hangzhou Dianzi ...
具体地,题目涉及到了斐波那契数列的一个变种:F(1)=1, F(2)=1, F(3)=1, F(4)=1, F(n>4)=F(n-1)+F(n-2)+F(n-3)+F(n-4),其中n > 4。这里的关键是要能够计算出F(n)的值,而由于这个序列的增长速度非常快,传统的整数...
【标签】"ACM题解 HDU"意味着这是一个关于如何解答HDU ACM题目的资源,可能包含了解题思路、算法解析、代码实现等方面的内容。这样的资料对于准备ACM比赛的选手或者希望提升算法能力的程序员来说非常有价值。 在...
ACM HDU 题目分类 ACM HDU 题目分类是指对 HDU 在线判题系统中题目的分类,总结了大约十来个分类。...ACM HDU 题目分类是一个非常重要的参考资源,对于编程选手来说,掌握这些分类可以帮助他们更好地理解和解决问题。
**第一步:线分割平面** 首先解决较为简单的二维情况,即如何用 _n_ 条直线分割一个平面,并求出最多可以将平面分割成多少部分。这里的关键在于理解每新增一条直线都会增加新的分割区域数。 - 对于第 _1_ 条直线,...
- **问题描述**:这是一道典型的0-1背包问题变种,考虑如何最大化抢劫金额,且不会被抓住。 - **解题思路**: - 定义状态$f[j]$表示在第$j$个地点抢劫的最大收益。 - 状态转移方程:$f[j] = \max\{f[j], f[j - q[i...
动态规划入门,hdu上的动态规划入门题的结题报告。 hdu 1171,hdu 1059,hdu 2159,hdu 2191,hdu 3496
hdu1001解题报告
HDU1059的代码
hdu 1574 passed sorce
HDU-ACM课件.rar 是一个专门为编程竞赛爱好者准备的资源包,主要涵盖了ACM(国际大学生程序设计竞赛)中常见的算法知识。这个压缩包包含了一系列与算法相关的主题,旨在帮助初学者理解和掌握基础及进阶算法。下面将...
此题目要求输入一个特定日期(格式为“年/月/日”),然后计算并输出这一天是一年中的第几天。例如,输入“2023/1/1”,则应该输出“1”。 ### 解题思路 1. **判断平年与闰年**:首先需要判断输入的年份是否为闰年...