HDU 2844 (多重背包)
2015-11-17 17:41
211 查看
题意是给你n个价值和对应的数量,问1到m之内有多少价值可以构造出来。
很裸的多重背包。
很裸的多重背包。
#include <bits/stdc++.h> using namespace std; #define maxn 111111 bool dp[maxn]; int a[maxn]; int p[maxn], tot, n, m; int main () { //freopen ("in", "r", stdin); while (scanf ("%d%d", &n, &m) == 2 && n+m) { for (int i = 1; i <= n; i++) { scanf ("%d", &a[i]); } tot = 0; for (int id = 1; id <= n; id++) { int cnt; scanf ("%d", &cnt); for (int i = 1; i <= cnt; i <<= 1) { p[tot++] = i*a[id]; cnt -= i; } if (cnt > 0) { p[tot++] = cnt*a[id]; } } memset (dp, 0, sizeof dp); dp[0] = 1; for (int i = 0; i < tot; i++) { for (int j = m-p[i]; j >= 0; j--) { dp[j+p[i]] = ((dp[j] == 1)|dp[j+p[i]]); } } int ans = 0; for (int i = 1; i <= m; i++) { if (dp[i]) { ans++; } } printf ("%d\n", ans); } return 0; }
相关文章推荐
- UICollectionView小结
- Redis监控方案
- 图片缓存之内存缓存技术LruCache,软引用
- linux系统编译安装软件的通用步骤
- 非最大值抑制nms
- php5.3升级php5.6
- hadoop估算π
- Yahoo开源的Apache Kafka管理工具:Kafka Manager
- OLED 程序
- 删数问题
- Linux下安装nginx和php
- Solr解析器通用的查询参数
- 杭电-5500Reorder the Books
- 碎片Fragment
- 应用dts在am335x上移植LCD(三)
- 图片在沙盒中的存在形式
- iOS_打包上传appStore
- 可折叠tableView - 仿照通讯录
- Linux下安装nginx和php
- 委托 Action与Func