九度oj 题目1455:珍惜现在,感恩生活
- 题目描述:
-
为了挽救灾区同胞的生命,心系灾区同胞的你准备自己采购一些粮食支援灾区,现在假设你一共有资金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:珍惜现在,感恩生活的更多相关文章
- 九度OJ 题目1384:二维数组中的查找
/********************************* * 日期:2013-10-11 * 作者:SJF0115 * 题号: 九度OJ 题目1384:二维数组中的查找 * 来源:http ...
- hdu 1284 关于钱币兑换的一系列问题 九度oj 题目1408:吃豆机器人
钱币兑换问题 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Sub ...
- 九度oj题目&吉大考研11年机试题全解
九度oj题目(吉大考研11年机试题全解) 吉大考研机试2011年题目: 题目一(jobdu1105:字符串的反码). http://ac.jobdu.com/problem.php?pid=11 ...
- 九度oj 题目1007:奥运排序问题
九度oj 题目1007:奥运排序问题 恢复 题目描述: 按要求,给国家进行排名. 输入: 有多组数据. 第一行给出国家数N,要求排名的国家数M,国家号 ...
- 九度oj 题目1087:约数的个数
题目链接:http://ac.jobdu.com/problem.php?pid=1087 题目描述: 输入n个整数,依次输出每个数的约数的个数 输入: 输入的第一行为N,即数组的个数(N<=1 ...
- 九度OJ题目1105:字符串的反码
tips:scanf,cin输入字符串遇到空格就停止,所以想输入一行字符并保留最后的"\0"还是用gets()函数比较好,九度OJ真操蛋,true?没有这个关键字,还是用1吧,还是 ...
- 九度oj题目1009:二叉搜索树
题目描述: 判断两序列是否为同一二叉搜索树序列 输入: 开始一个数n,(1<=n<=20) 表示有n个需要判断,n= 0 的时候输入结束. 接 ...
- 九度oj题目1002:Grading
//不是说C语言就是C++的子集么,为毛printf在九度OJ上不能通过编译,abs还不支持参数为整型的abs()重载 //C++比较正确的做法是#include<cmath.h>,cou ...
- 九度OJ题目1003:A+B
while(cin>>str1>>str2)就行了,多简单,不得不吐槽,九度的OJ真奇葩 题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号", ...
随机推荐
- Jmeter进行接口的性能测试
一.录制Jmeter脚本 录制Jmeter脚本有两种方法,一种是设置代理:一种则是利用badboy软件,badboy软件支持导出jmx脚本. 这里我们介绍第二种方法,利用badboy录制脚本,然后导出 ...
- 【转】iOS-生成Bundle包-引入bundle-使用bundle
在我们使用第三方框架时,常常看到XXX.bundle的文件. 我们找到该文件,显示包内容,大致看到很多资源文件:图片.配置文本.XIB文件…… 什么是Bundle文件? 简单理解,就是资源文件包. ...
- 使用Timer组件制作左右飘动的窗体
实现效果: 知识运用: Form类的Left和Top属性 实现代码: private void timer1_Tick(object sender, EventArgs e) { Rectangle ...
- 用 label 控制 Pod 的位置
默认配置下,Scheduler 会将 Pod 调度到所有可用的 Node.不过有些情况我们希望将 Pod 部署到指定的 Node,比如将有大量磁盘 I/O 的 Pod 部署到配置了 SSD 的 Nod ...
- JavaScript BOM DOM 对象
title: JavaScript BOM DOM 对象 tags: JavaScript --- browser object model document onject model BOM对象 w ...
- vue跨域处理(vue项目中baseUrl设置问题)
1.开发环境: 2.生产环境: 然后 const instance = axios.create({ baseURL: process.env.API })
- 关于在vue 中使用百度ueEditor
1. 安装 npm i vue-ueditor --save-dev 2.从nodemodels 取出ueditor1_4_3_3 这整个目录,放入vue 的 static 目录 3.配置 ued ...
- C++ string头文件
转载自https://blog.csdn.net/superna666/article/details/52809007/ 作者 zhenzhenjiajia888 标准c++中string类函数介绍 ...
- 【NOIP2017提高A组冲刺11.8】好文章
#include<algorithm> #include<iostream> #include<cstring> #include<cstdio> us ...
- How to Install Zabbix Server on Centos6.7
Prerequisite Environment First you must use your Subscription Manager to enable SCL: [root@fileserve ...