hdu1114 Piggy-Bank
2016-04-05 23:54
260 查看
题意:给一个t,表示t组样例,接下来输入e,f 表示罐子重e,装满后重f,输入n,接下来n行,有n中钱,分别有w[i],p[i],两个属性,问,罐子装满后最少的钱,如果不能装满输出This is impossible.
分析:明显的完全背包问题(一开始写超时了,转化成了01背包写,没想到也超时了,后来发现dp数组开的太小了)
分析:明显的完全背包问题(一开始写超时了,转化成了01背包写,没想到也超时了,后来发现dp数组开的太小了)
#include <iostream> #include <cstdio> #include <cstring> #include <algorithm> #include <cstdlib> #include <ctime> using namespace std; int p[555], w[555]; int dp[10003]; const int oo = 1e9; int main() { int t, e, f, n; scanf("%d", &t); while(t--) { scanf("%d%d", &e, &f); scanf("%d", &n); dp[0] = 0; for(int i=1; i<=n; i++) { scanf("%d%d", &p[i], &w[i]); } for(int i=1; i<=f-e; i++) dp[i]=oo; for(int i=1; i<=n; i++) { for(int j=w[i]; j<=f-e; j++) { dp[j] = min(dp[j], dp[j-w[i]]+p[i]); } } if(dp[f-e]!=oo) printf("The minimum amount of money in the piggy-bank is %d.\n", dp[f-e]); else printf("This is impossible.\n"); } return 0; }
相关文章推荐
- lazy loading
- bzoj1101【POI007】Zap
- Ubuntu sudo不用密码
- 单链表中查找倒数第K个节点
- sql基础--怎样让查询出来的数据只返回多少行
- 建造博客屋伊始
- 《JAVA并发编程实践》学习笔记(第二章)
- React 同构
- nginx cdn加速和反向代理
- bzoj2154 Crash的数字表格
- linux 部分常用命令(20个)
- Android电源管理 -- wakelock机制
- PT Pascal Compiler using S/SL
- wget获取https资源
- 自定义gallery(画廊)
- Genymotion镜像网盘下载
- 2016年最值得应聘的十家互联网公司
- linux下编译使用lua及cjson
- 终端模式下交换caps和ctrl键
- BZOJ 3697 采药人的路径 点分治