●BZOJ 1531 [POI2005]Bank notes
题链:
http://www.lydsy.com/JudgeOnline/problem.php?id=1531
题解:
单调队列优化多重背包DP
(弱弱的我今天总算是把这个坑给填了。。。)
令V[i]为第i种硬币的面值,C[i]为第i种硬币的数目。
定义DP[i][j]表示用了前i种硬币,凑出面值为j的最小硬币数。
先看看这个题用最裸的背包是如何转移的:
DP[i][j]=min(dp[i-1][j-k*V[i]]]+k)
然后,我们令 a=⌊j÷V[i]⌋ (⌊ ⌋:向下取整),b=j%V[i]
那么 j=a*V[i]+b
接下来这样考虑,对于一个当前计算的总面值j,
同样枚举k,但不再像之前那样表示选择了几个i号硬币,
而是表示相对于a而言,少选几个i号硬币。
换句话说,我们对于当前的j,在默认要选a个i号硬币基础上,去枚举少选k个该硬币。
那么怎样转移呢:
DP[i][j]=min(dp[i-1][b+K*V[i]]+a-k)
其实意思还是很明了的,就是选了 a-k 个i号硬币嘛。(好好理解一下)
然后可以把取小项里面的a提出来:
DP[i][j]=min(dp[i-1][b+K*V[i]]-k)+a
再看看这个式子,如果固定i和b,取小项里面就只有K是变化的,
把其看成是一个只与k有关的函数,
显然就可以用单调队列维护最小值然后O(1)转移啦。
具体做法是:
第一层循环先枚举硬币i,
第二层循环再枚举一个b值,
第三层循环接着枚举j,需要满足j=b+a*V[i]
然后第三层循环里面的转移就可以用单调队列维护了,
总的复杂度为 O(N*M)
代码:
#include<cstdio>
#include<cstring>
#include<iostream>
#define MAXN 205
#define MAXM 20005
using namespace std;
int V[MAXN],C[MAXN],DP[MAXN][MAXM];
int N,M;
int main(){
static int QK[MAXM],l,r;
scanf("%d",&N);
for(int i=1;i<=N;i++) scanf("%d",&V[i]);
for(int i=1;i<=N;i++) scanf("%d",&C[i]);
memset(DP,0x3f,sizeof(DP));
scanf("%d",&M);
DP[0][0]=0;
for(int i=1;i<=N;i++){
for(int b=0,a;b<V[i];b++){
l=1; r=0;
for(int j=b;a=j/V[i],j<=M;j+=V[i]){
while(l<=r&&DP[i-1][b+QK[r]*V[i]]-QK[r]>=DP[i-1][b+a*V[i]]-a) r--;
QK[++r]=a;
while(l<=r&&a-QK[l]>C[i]) l++;
DP[i][j]=DP[i-1][b+QK[l]*V[i]]-QK[l]+a;
}
}
}
printf("%d",DP[N][M]);
return 0;
}
●BZOJ 1531 [POI2005]Bank notes的更多相关文章
- BZOJ 1531: [POI2005]Bank notes( 背包 )
多重背包... ---------------------------------------------------------------------------- #include<bit ...
- BZOJ 1531: [POI2005]Bank notes
按余数分类 单调队列优化 #include<cstdio> using namespace std; int n,m,b[205],c[205],F[20005]; struct node ...
- 1531: [POI2005]Bank notes二进制优化(c++)
Description Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,..., bn. 但是每种硬币有数量限制,现在我 ...
- bzoj1531[POI2005]Bank notes 单调队列优化dp
1531: [POI2005]Bank notes Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 559 Solved: 310[Submit][Sta ...
- bzoj1531: [POI2005]Bank notes(多重背包)
1531: [POI2005]Bank notes Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 521 Solved: 285[Submit][Sta ...
- bzoj1531: [POI2005]Bank notes
Description Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,..., bn. 但是每种硬币有数量限制,现在我 ...
- 【bzoj1531】[POI2005]Bank notes 多重背包dp
题目描述 Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,..., bn. 但是每种硬币有数量限制,现在我们想要凑出面值 ...
- 2018.09.08 bzoj1531: [POI2005]Bank notes(二进制拆分优化背包)
传送门 显然不能直接写多重背包. 这题可以用二进制拆分/单调队列优化(感觉二进制好写). 所谓二进制优化,就是把1~c[i]拆分成20,21,...2t,c[i]−2t+1+1" role= ...
- [POI2005]Bank notes
link 试题分析 我们发现此题是一个十分简单的多重背包.但是按照朴素写法会超时.所以要去考虑优化. 我们发现我们若$W=7$,可以拆成$1+2+4$,不用每次$1+1+1+1+1+1+1$,从$N$ ...
随机推荐
- 项目Beta预备
项目名称:城市安全风险管控系统 Beta预备: 讨论组长是否重选的议题和结论 项目组长可以说是一个团队的灵魂和核心.一个好的领导者可以激发团队成员的工作热情,提高开发效率,保质保量的完成工作.虽然在A ...
- Git学习使用
1.注册码云并建立远程仓库 2.安装git 3.使用eclipse egit 推送以及克隆 建立本地仓库,成功后如图 推送项目至本地仓库与远程仓库 使用右键菜单team-share 选项,与仓库关联后 ...
- 实现mypwd
1 学习pwd命令 2 研究pwd实现需要的系统调用(man -k; grep),写出伪代码 3 实现mypwd 4 测试mypwd 提交过程博客的链接 代码如图
- Scrum 冲刺 第二日
Scrum 冲刺 第二日 目录 要求 项目链接 燃尽图 问题 今日任务 明日计划 成员贡献量 要求 各个成员今日完成的任务(如果完成的任务为开发或测试任务,需给出对应的Github代码签入记录截图:如 ...
- AWS EC2服务器的HTTPS负载均衡器配置过程
AWS EC2服务器配置负载均衡器步骤: 1.普通负载均衡器 至少两台EC2实例,这里以Centos6.7系统为例 启动之后先安装个apache的httpd服务器默认80端口,或者使用其他服务 ...
- MySql使用存储过程实现事务的提交或者回滚
DELIMITER $$ DROP PROCEDURE IF EXISTS test_sp1 $$ CREATE PROCEDURE test_sp1( ) BEGIN ; ; START TRANS ...
- jvm垃圾收集器总结jdk1.7
内存 ● 线程私有:程序计数器,虚拟机栈,本地方法栈 ● 线程共享: 方法区,堆 判断存活算法 ● 引用计数法:无法解决循环引用问题. ● 可达性分析算法: 从GCRoot作为起始点,向下搜索,经过的 ...
- EXT3文件系统误删除导致文件系统中的邮件丢失恢复方法
一.故障描述 由8块盘组成的RAID5, 上层是EXT3文件系统,由于误删除导致文件系统中的邮件丢失 二.镜像磁盘为防止数据恢复过程中由于误操作对原始磁盘造成二次破坏, 使用winhex软件为每块磁盘 ...
- 如何进行服务器Linux系统下的ext文件系统修复
一.故障描述 服务器是dell 730系列服务器,存储阵列是MD3200系列存储5T的Lun,操作系统是Linux centos 7,文件系统类型是EXT4,因意外断电,导致系统不能正常启动,修复之后 ...
- 15-TypeScript策略模式
在前面的简单工厂模式中,通常将每个类.接口定义到不同的文件中.在面向对象开发思想中有一个重要的原则就是封装变化点,在实际操作过程中, 通常被调用方的代码不要去更改,而是增加,这是面向对象的开闭原则.在 ...