POJ1384Piggy-Bank(DP)
POJ1384http://poj.org/problem?id=1384
最简单的完全背包问题,注意下初始化为INF就可以。
1 #include <map> 2 #include <set> 3 #include <stack> 4 #include <queue> 5 #include <cmath> 6 #include <ctime> 7 #include <vector> 8 #include <cstdio> 9 #include <cctype> 10 #include <cstring> 11 #include <cstdlib> 12 #include <iostream> 13 #include <algorithm> 14 using namespace std; 15 #define INF 0x3f3f3f3f 16 #define MAX(a,b) (a > b ? a : b) 17 #define MIN(a,b) (a < b ? a : b) 18 #define mem0(a) memset(a,0,sizeof(a)) 19 20 typedef long long LL; 21 const double eps = 1e-12; 22 const int MAXN = 1005; 23 const int MAXM = 5005; 24 25 int T, N, E, F; 26 int DP[11000], P[550], W[550]; 27 28 int main() 29 { 30 scanf("%d", &T); 31 while(T--) 32 { 33 scanf("%d %d", &E, &F); 34 F -= E; 35 for(int i=0;i<=F;i++) DP[i] = INF; 36 scanf("%d", &N); 37 for(int i=0;i<N;i++) scanf("%d %d", &P[i], &W[i]); 38 DP[0] = 0; 39 for(int i=0;i<N;i++) 40 { 41 for(int j=W[i];j<=F;j++) 42 { 43 if(DP[j] > DP[j-W[i]] + P[i]) 44 { 45 DP[j] = DP[j-W[i]] + P[i]; 46 } 47 } 48 } 49 if(DP[F] == INF) printf("This is impossible.\n"); 50 else printf("The minimum amount of money in the piggy-bank is %d.\n", DP[F]); 51 } 52 return 0; 53 }
转载于:https://www.cnblogs.com/gj-Acit/p/3440521.html
POJ1384Piggy-Bank(DP)相关推荐
- 求三角形最大面积(DP)
求三角形最大面积(DP) 在OJ上奇迹般WA了:WA:70. Why? #include <iostream> #include <string.h> using namesp ...
- LeetCode 编辑距离 II(DP)
1. 题目 给你两个单词 s 和 t,请你计算出将 s 转换成 t 所使用的最少操作数. 你可以对一个单词进行如下两种操作: 删除一个字符 替换一个字符 注意: 不允许插入操作 题目保证有解 示例: ...
- LeetCode 1220. 统计元音字母序列的数目(DP)
文章目录 1. 题目 2. 解题 1. 题目 给你一个整数 n,请你帮忙统计一下我们可以按下述规则形成多少个长度为 n 的字符串: - 字符串中的每个字符都应当是小写元音字母('a', 'e', 'i ...
- LeetCode 265. 粉刷房子 II(DP)
文章目录 1. 题目 2. 解题 1. 题目 假如有一排房子,共 n 个,每个房子可以被粉刷成 k 种颜色中的一种,你需要粉刷所有的房子并且使其相邻的两个房子颜色不能相同. 当然,因为市场上不同颜色油 ...
- LeetCode 256. 粉刷房子(DP)
文章目录 1. 题目 2. 解题 1. 题目 假如有一排房子,共 n 个,每个房子可以被粉刷成红色.蓝色或者绿色这三种颜色中的一种,你需要粉刷所有的房子并且使其与相邻的两个房子颜色不能相同. 当然,因 ...
- LeetCode 1223. 掷骰子模拟(DP)
1. 题目 有一个骰子模拟器会每次投掷的时候生成一个 1 到 6 的随机数. 不过我们在使用它时有个约束,就是使得投掷骰子时,连续 掷出数字 i 的次数不能超过 rollMax[i](i 从 1 开始 ...
- LeetCode 1155. 掷骰子的N种方法(DP)
1. 题目 这里有 d 个一样的骰子,每个骰子上都有 f 个面,分别标号为 1, 2, -, f. 我们约定:掷骰子的得到总点数为各骰子面朝上的数字的总和. 如果需要掷出的总点数为 target,请你 ...
- LeetCode 1139. 最大的以 1 为边界的正方形(DP)
1. 题目 给你一个由若干 0 和 1 组成的二维网格 grid,请你找出边界全部由 1 组成的最大 正方形 子网格,并返回该子网格中的元素数量.如果不存在,则返回 0. 示例 1: 输入:grid ...
- 程序员面试金典 - 面试题 17.23. 最大黑方阵(DP)
1. 题目 给定一个方阵,其中每个单元(像素)非黑即白. 设计一个算法,找出 4 条边皆为黑色像素的最大子方阵. 返回一个数组 [r, c, size] ,其中 r, c 分别代表子方阵左上角的行号和 ...
- LeetCode 1406. 石子游戏 III(DP)
1. 题目 Alice 和 Bob 用几堆石子在做游戏.几堆石子排成一行,每堆石子都对应一个得分,由数组 stoneValue 给出. Alice 和 Bob 轮流取石子,Alice 总是先开始.在每 ...
最新文章
- 独家 | 7招帮你打造完美数据科学GitHub作品集!
- WPF ValidationRule的特点(默认目标-源才校验)
- 644 - Immediate Decodability
- 2022版全球及中国消防设备市场营销策略分析与竞争趋势展望报告
- python报错:ImportError: cannot import name autojit from numba(无法导入numba.autojit)
- 网络安全技术——数字证书技术原理
- Netgear wndr3700v2 路由器刷OpenWrt打造全能服务器(五)SVN服务
- main spring启动_SpringBoot学习(一):为什么main方法启动类需要放在项目根目录...
- xml中的Document和Attribute
- DB2数据库指定时间点恢复案例
- UVa1592 数据库(摘)
- larvel mysql count,Laravel带条件查询多个count
- JavaScript浏览器对象(BOM)中有关设备、浏览器屏幕高度和宽度的API介绍
- java超市管理系统ppt_基于java-web的超市管理系统毕业答辩ppt课件
- windows虚拟串口服务器,USR-TCP232-T24系列串口服务器建立虚拟串口方法
- 双11有哪些好用的降噪蓝牙耳机值得推荐?降噪蓝牙耳机性价比排行
- 华三交换机怎么样?H3C交换机产品系列介绍!
- CAD教程:CAD软件中怎么将图块改层?
- 基于XBee进行ZigBee组网(二)——ZigBee网络与XCTU的使用
- meshgrid()函数