题目描述:

为了挽救灾区同胞的生命,心系灾区同胞的你准备自己采购一些粮食支援灾区,现在假设你一共有资金n元,而市场有m种大米,每种大米都是袋装产品,其价格不等,并且只能整袋购买。请问:你用有限的资金最多能采购多少公斤粮食呢?

输入:

输入数据首先包含一个正整数C,表示有C组测试用例,每组测试用例的第一行是两个整数n和m(1<=n<=100, 1<=m<=100),分别表示经费的金额和大米的种类,然后是m行数据,每行包含3个数p,h和c(1<=p<=20,1<=h<=200,1<=c<=20),分别表示每袋的价格、每袋的重量以及对应种类大米的袋数。

输出:

对于每组测试数据,请输出能够购买大米的最多重量,你可以假设经费买不光所有的大米,并且经费你可以不用完。每个实例的输出占一行。

样例输入:
1
8 2
2 100 4
4 100 2
样例输出:
400

以前总想接触一下多重背包问题,今天终于遇到了。
这是一个多重背包问题,简单来讲,就是每个重量的物品不是只有一个,也不是无限个,而是有限数量个
一开始的思路是转换成普通的背包问题来解决,也就是把每类物品当成是一个个的物品
代码如下
 #include <cstdio>
#include <iostream>
#include <cstring>
using namespace std;
int n,m;
int p[];
int w[];
int c[];
int dp[]; int main(int argc, char const *argv[])
{
int C;
//freopen("input.txt","r",stdin);
while(scanf("%d",&C) != EOF) {
while(C--) {
scanf("%d %d",&n,&m);
for(int i = ; i < m; i++) {
scanf("%d %d %d",&p[i],&w[i],&c[i]);
}
memset(dp, , sizeof(dp));
for(int i = ; i < m; i++) {
for(int j = ; j <= c[i]; j++) {
for(int k = n; k >= p[i]; k--) {
dp[k] = max(dp[k],dp[k-p[i]]+w[i]);
}
} }
printf("%d\n",dp[n]);
}
}
return ;
}

当然,这个问题还有一些巧妙的解决技巧

比如一件物品有6件,我们假如把它分成1 + 2 +3 件,你会发现,用1,2,3可以凑出任意一个1到6的数

这样的拆分方法是把一个数拆分成2的幂次方的和,如果不能整拆,则最后一个数为差

譬如10可以拆分成1 +2 + 4 +        3

那么我们可以用这些数去构成相应价值的物品

代码如下:

 #include <cstdio>
#include <iostream>
#include <cstring>
using namespace std;
int n,m;
int p[];
int w[];
int c[];
int dp[]; int main(int argc, char const *argv[])
{
int C;
//freopen("input.txt","r",stdin);
while(scanf("%d",&C) != EOF) {
while(C--) {
scanf("%d %d",&n,&m);
int cnt = ;
for(int i = ; i < m; i++) {
int pt,wt,ct;
scanf("%d %d %d",&pt,&wt,&ct);
int c = ;
while(ct - c > ) {
p[cnt] = c * pt;
w[cnt] = c * wt;
ct = ct - c;
cnt++;
c *= ;
}
p[cnt] = ct*pt;
w[cnt] = ct*wt;
cnt++;
}
memset(dp, , sizeof(dp));
for(int i = ; i < cnt; i++) {
for(int k = n; k >= p[i]; k--) {
dp[k] = max(dp[k],dp[k-p[i]]+w[i]);
} }
printf("%d\n",dp[n]);
}
}
return ;
}

九度oj 题目1455:珍惜现在,感恩生活的更多相关文章

  1. 九度OJ 题目1384:二维数组中的查找

    /********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...

  2. hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人

    钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Sub ...

  3. 九度oj题目&amp;吉大考研11年机试题全解

    九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码).    http://ac.jobdu.com/problem.php?pid=11 ...

  4. 九度oj 题目1007:奥运排序问题

    九度oj 题目1007:奥运排序问题   恢复 题目描述: 按要求,给国家进行排名. 输入:                        有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...

  5. 九度oj 题目1087:约数的个数

    题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...

  6. 九度OJ题目1105:字符串的反码

    tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...

  7. 九度oj题目1009:二叉搜索树

    题目描述: 判断两序列是否为同一二叉搜索树序列 输入:                        开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...

  8. 九度oj题目1002:Grading

    //不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...

  9. 九度OJ题目1003:A+B

    while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...

随机推荐

  1. POJ 1067 取石子游戏 (威佐夫博奕,公式)

    题意: 有两堆石子,两个人轮流取石子.规定每次有两种取法,一是可以在任意的一堆中取走任意多的石子:二是可以在两堆中同时取走相同数量的石子.最后把石子全部取完者为胜者.给定两堆石子数量,问先手的输赢? ...

  2. cv2.Canny 边缘检测

    Canny边缘检测   Canny 的目标是找到一个最优的边缘检测算法,最优边缘检测的含义是: 好的检测 - 算法能够尽可能多地标识出图像中的实际边缘. 好的定位 - 标识出的边缘要尽可能与实际图像中 ...

  3. python 基础之格式化输出

    字符占位符%s #_cvvh:"chenxi" #date: 2019/6/24 print ('chhjg') # 格式化输出 name = input("Name:& ...

  4. python_94_类变量实例变量

    class Role: n=123#类变量 name='我是类name' list=[] def __init__(self,name,role,weapon,life_value=100,money ...

  5. Vue处理ajax请求

    Ajax请求 1>解决跨域问题 1.1前端解决.只需要在vue.config.js中增加devServer节点增加代理: const path = require("path" ...

  6. java基础—this关键字

    一.this关键字

  7. Mybatis学习记录(2)

    1.mybatis与hibernate不同 Mybatis和hibernate,mybatis不完全是一个ORM框架,因为Mybatis需要程序员自己编写sql语句.mybatis可以通过xml或注解 ...

  8. 【模拟】HHHOJ#251. 「NOIP模拟赛 伍」高精度

    积累模拟经验 题目描述 维护一个二进制数,支持如下操作 "+" 该数加 11 "-" 该数减 11 "*" 该数乘 22 "\&q ...

  9. GoogleTest 之路1-Generic Build Instructions编译指导总方案

    准备工作 为了在你的测试中使用GoogleTest, 你必须让你的编译系统 知道到哪里去寻找GoogleTest 的头文件和源文件. 具体的方法只能依赖于你具体使用的哪种编译系统了,一般来讲这个非常容 ...

  10. biological clock--class

    '''this application aimed to cauculate people's biological block about emotional(28), energy(23),int ...