Typesetting math: 100%
博客园 首页 私信博主 显示目录 隐藏目录 管理 动画

单调队列优化多重背包

题目描述

N 种物品和一个容量是 V 的背包。

i 种物品最多有 si 件,每件体积是 vi,价值是 wi

求解将哪些物品装入背包,可使物品体积总和不超过背包容量,且价值总和最大。
输出最大价值。

范围

0<N1000
0<V20000
0<vi,wi,si20000

题解

考虑fjk×v是由若干个{fj,fj+v,fj+2v}最大值转移而来。

写出dp方程之后用单调队列转移即可。

代码

#include <bits/stdc++.h>
using namespace std;
const int N = 20010;
int n,m;
int pre[N];
int dp[N];
int q[N];

int main () {
	cin >> n >> m;
	for(int i = 1;i <= n; ++i) {
		int s,v,w;
		cin >> v >> w >> s;
		memcpy(pre,dp,sizeof dp);
		for(int j = 0;j < v; ++j) {
			int head = 1;
			int tail = 0;
			for(int k = j;k <= m; k += v) {
				while(head <= tail and q[head] < k - s * v) head ++;
				while(head <= tail and pre[q[tail]] - (q[tail] - j) / v * w <= pre[k] - (k - j) / v * w)
					tail --;
				q[++tail] = k;
				if(head <= tail) dp[k] = pre[q[head]] - (q[head] - k) / v * w;
			}
		}
	}
	cout << dp[m] << endl;
	return 0;
}

posted @   Allorkiya  阅读(76)  评论(0编辑  收藏  举报
编辑推荐:
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
阅读排行:
· PPT革命!DeepSeek+Kimi=N小时工作5分钟完成?
· What?废柴, 还在本地部署DeepSeek吗?Are you kidding?
· DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
· 程序员转型AI:行业分析
· 重磅发布!DeepSeek 微调秘籍揭秘,一键解锁升级版全家桶,AI 玩家必备神器!
历史上的今天:
2018-08-17 [CTSC 2012]熟悉的文章
点击右上角即可分享
微信分享提示