BZOJ 1531 POI2005 Bank notes 多重背包

题目大意:多重背包

一大早就水了个题233

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#define M 20200
using namespace std;
int n,k,b[220],c[220];
int f[M];
int main()
{
	int i,j,k;
	cin>>n;
	for(i=1;i<=n;i++)
		scanf("%d",&b[i]);
	for(i=1;i<=n;i++)
		scanf("%d",&c[i]);
	cin>>::k;
	memset(f,0x3f,sizeof f);
	f[0]=0;
	for(i=1;i<=n;i++)
	{
		for(j=1;j<=c[i];j<<=1)
		{
			for(k=::k;k>=b[i]*j;k--)
				f[k]=min(f[k],f[k-b[i]*j]+j);
			c[i]-=j;
		}
		if(!c[i]) continue;
		j=c[i];
		for(k=::k;k>=b[i]*j;k--)
				f[k]=min(f[k],f[k-b[i]*j]+j);
	}
	cout<<f[::k]<<endl;
	return 0;
}
时间: 2024-12-19 00:36:29

BZOJ 1531 POI2005 Bank notes 多重背包的相关文章

BZOJ 1531: [POI2005]Bank notes( 背包 )

多重背包... ---------------------------------------------------------------------------- #include<bits/stdc++.h> #define rep(i, n) for(int i = 0; i < n; i++) #define clr(x, c) memset(x, c, sizeof(x)) using namespace std; const int maxn = 209, maxk =

【bzoj1531】[POI2005]Bank notes 多重背包dp

题目描述 Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,..., bn. 但是每种硬币有数量限制,现在我们想要凑出面值k求最少要用多少个硬币. 输入 第一行一个数 n, 1 <= n <= 200. 接下来一行 n 个整数b1, b2,..., bn, 1 <= b1 < b2 < ... < b n <= 20 000, 第三行 n 个整数c1, c2,..., cn, 1 <

BZOJ 1531 POI2005 Bank notes

多重背包问题,二进制拆分后做~ #include <cstdio> #include <algorithm> #include <cstring> #define up(a,b,c) for(register int c=a;c<=b;++c) #define down(a,b,c) for(register int c=a;c>=b;--c) typedef long long ll; ll n,x; ll num[205],value[205],Aim,

1531: [POI2005]Bank notes二进制优化(c++)

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,...,

【BZOJ 1531】 [POI2005]Bank notes

1531: [POI2005]Bank notes Time Limit: 5 Sec Memory Limit: 64 MB Submit: 271 Solved: 139 [Submit][Status][Discuss] Description Byteotian Bit Bank (BBB) 拥有一套先进的货币系统,这个系统一共有n种面值的硬币,面值分别为b1, b2,-, bn. 但是每种硬币有数量限制,现在我们想要凑出面值k求最少要用多少个硬币. Input 第一行一个数 n, 1

BZOJ1531: [POI2005]Bank notes

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 <

BZOJ 3163 Heoi2013 Eden的新背包问题 多重背包

题目大意:多重背包,多次询问某个物品不能选择时以某个总价钱最多能获得多少价值 求问正解是啥QAQ 维护一个前缀多重背包和一个后缀多重背包 每次询问时 枚举前面选多少和后面选多少 暴力统计答案即可 时间复杂度O(n^2logn+nq) 这3E的复杂度居然只跑了600sQAQ 正解到底是啥QAQ #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> #defin

poj1276——dp,多重背包

poj1276——dp,多重背包 Cash Machine Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 28826   Accepted: 10310 Description A Bank plans to install a machine for cash withdrawal. The machine is able to deliver appropriate @ bills for a requested c

POJ1276Cash Machine[多重背包可行性]

Cash Machine Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 32971   Accepted: 11950 Description A Bank plans to install a machine for cash withdrawal. The machine is able to deliver appropriate @ bills for a requested cash amount. The m