博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JXFCZX — 庆功会(多重背包)
阅读量:1999 次
发布时间:2019-04-28

本文共 1160 字,大约阅读时间需要 3 分钟。

题目链接:

时间:1 秒 空间:512 MB

题目描述

为了庆贺班级在校运动会上取得全校第一名成绩,班主任决定开一场庆功会,为此拨款购买奖品犒劳运动员。 期望拨款金额能购买最大价值的奖品,可以补充他们的精力和体力。

输入

第一行二个数n(n≤500),m(m≤6000),其中n代表希望购买的奖品的种数,m表示拨款金额。

接下来n行,每行3个数,v、w、s,分别表示第I种奖品的价格、价值(价格与价值是不同的概念)和能购买的最大数量(买0件到s件均可),其中v≤100,w≤1000,s≤10。

输出

一行:一个数,表示此次购买能获得的最大的价值(注意!不是价格)。

样例输入

5 1000

80 20 4
40 50 9
30 50 7
40 30 6
20 20 1

样例输出

1040

解题思路

多重背包。

Accepted Code:

#include 
using namespace std;int dp[6005], p;void CompletePack(int w, int v) { for (int j = w; j <= p; j++) dp[j] = max(dp[j - w] + v, dp[j]);}void ZeroOnePack(int w, int v) { for (int j = p; j >= w; j--) dp[j] = max(dp[j - w] + v, dp[j]);}void MultiplePack(int w, int v, int m) { if (w * m >= p) {//如果物品的数量足够多,完全可以满足体积限制,那么就转化为完全背包问题(不限制每种物品的数量) CompletePack(w, v);//完全背包 return ; } int k = 1; while (k < m) {//二进制优化 ZeroOnePack(k * w, k * v); m -= k; k <<= 1; } ZeroOnePack(m * w, m * v);//物品还有剩余用01背包 }int main() { int n, u, v, w; scanf("%d%d", &n, &p); for (int i = 0; i < n; i++) { scanf("%d%d%d", &w, &v, &u); MultiplePack(w, v, u); } printf("%d\n", dp[p]); return 0;}

转载地址:http://fqftf.baihongyu.com/

你可能感兴趣的文章
面向初学者的DPDK技术解析
查看>>
重磅发布: 营销数据中台白皮书(附全文下载)
查看>>
解惑: GPU产品的关键参数和应用场景
查看>>
华芯通关闭引发的深度思考
查看>>
图解分布式架构的发展和演进
查看>>
这4种常用的软件架构,到底有何不同?
查看>>
中国SaaS的机遇、战术和野心
查看>>
浅谈几种常用负载均衡架构
查看>>
如何快速深入理解监控知识?
查看>>
Redhat Ceph存储之“深入理解Ceph架构”
查看>>
干货分享: Ceph原理、架构等知识梳理总结
查看>>
[深度] Intel和ARM双雄争霸: 读懂芯片前世今生
查看>>
芯片战争: 开源架构RISC-V前世今生
查看>>
详谈四大主流CPU体系架构
查看>>
芯片之路: 海思半导体前世今生
查看>>
操作系统: Unix操作系统演进简史
查看>>
基础知识:你真的了解云计算吗?
查看>>
一文读懂云计算、边缘计算、移动边缘计算和自动驾驶的前世今生!
查看>>
基础知识:你真的了解云计算吗?
查看>>
芯片之争: MIPS走上开源道路!
查看>>