BZOJ1531: [POI2005]Bank notes
2014-10-03 00:28
232 查看
1531: [POI2005]Bank notes
Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 229 Solved: 119
[Submit][Status]
Description
Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,..., bn. 但是每种硬币有数量限制,现在我们想要凑出面值k求最少要用多少个硬币.Input
第一行一个数 n, 1 <= n <= 200. 接下来一行 n 个整数b1, b2,..., bn, 1 <= b1 < b2 < ... < b n <= 20 000, 第三行 n 个整数c1, c2,..., cn, 1 <= ci <= 20 000, 表示每种硬币的个数.最后一行一个数k – 表示要凑的面值数量, 1 <= k <= 20 000.Output
第一行一个数表示最少需要付的硬币数Sample Input
Sample Output
HINT
Source
题解:应该算是一个比较裸的多重背包问题。
顺便复习了下 单调队列优化多重背包 。
好像很优越:对于第 i 种物品来说,已知体积 v,价值 w,数量 k,那么可以按照当
我们可以把每一份分开处理,假设余数为 d。
现在看到分组以后,编号 j 可以从 j-k 到 j-1 中的任意一个编号转移而
来(因为相邻的体积正好相差 v),这看上去已经和区间最大值有点相似了。
但是注意到由于体积不一样,显然体积大的价值也会大于等于体积小的,
直接比较是没有意义的,所以还需要把价值修正到同一体积的基础上。比
如都退化到 d,也就是说用 F[j*v+d]- j*w 来代替原来的价值进入队列
代码:
#include<cstdio> #include<cstdlib> #include<cmath> #include<cstring> #include<algorithm> #include<iostream> #include<vector> #include<map> #include<set> #include<queue> #include<string> #define inf 1000000000 #define maxn 50000 #define maxm 500+100 #define eps 1e-10 #define ll long long #define pa pair<int,int> #define for0(i,n) for(int i=0;i<=(n);i++) #define for1(i,n) for(int i=1;i<=(n);i++) #define for2(i,x,y) for(int i=(x);i<=(y);i++) #define for3(i,x,y) for(int i=(x);i>=(y);i--) #define mod 1000000007 using namespace std; inline int read() { int x=0,f=1;char ch=getchar(); while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();} while(ch>='0'&&ch<='9'){x=10*x+ch-'0';ch=getchar();} return x*f; } int n,m,a[maxn],b[maxn],f[maxn]; struct rec{int x,y;}q[maxn]; int main() { freopen("input.txt","r",stdin); freopen("output.txt","w",stdout); n=read(); for1(i,n)a[i]=read(); for1(i,n)b[i]=read(); m=read(); memset(f,60,sizeof(f)); f[0]=0; for1(i,n) { for0(j,a[i]-1) { int l=1,r=0; for0(k,(m-j)/a[i]) { int t=k*a[i]+j; while(l<=r&&q[r].y>f[t]-k)r--; q[++r].x=k;q[r].y=f[t]-k; while(l<=r&&q[l].x<k-b[i])l++; if(l<=r)f[t]=min(f[t],q[l].y+k); } } } printf("%d\n",f[m]); return 0; }
View Code
相关文章推荐
- [BZOJ1531] [POI2005]Bank notes
- bzoj1531[POI2005]Bank notes 多重背包
- BZOJ 1531 POI2005 Bank notes 多重背包
- bzoj 1531: [POI2005]Bank notes
- 【多重背包小小的优化(。・∀・)ノ゙】BZOJ1531-[POI2005]Bank notes
- bzoj1531[POI2005]Bank notes 单调队列优化dp
- BZOJ 1531: [POI2005]Bank notes 多重背包
- BZOJ 1531: [POI2005]Bank notes( 背包 )
- ●BZOJ 1531 [POI2005]Bank notes
- bzoj 1531: [POI2005]Bank notes
- 【BZOJ1531】[POI2005]Bank notes【多重背包】
- 【bzoj1531】[POI2005]Bank notes 多重背包dp
- 【BZOJ 1531】 [POI2005]Bank notes
- bzoj 1531: [POI2005]Bank notes 单调队列优化多重背包
- 【BZOJ】【P1531】【POI2005】【Bank notes】【题解】【二进制优化背包】【300T留念】
- 1531: [POI2005]Bank notes (动态规划)
- 【BZOJ】【1529】 【POI2005】ska Piggy banks
- 【bzoj1528】[POI2005]sam-Toy Cars
- bzoj 1539: [POI2005]Dwu-Double-row
- bzoj1532 [POI2005]Kos-Dicing