Day9 - D - Piggy-Bank POJ - 1384
But there is a big problem with piggy-banks. It is not possible to determine how much money is inside. So we might break the pig into pieces only to find out that there is not enough money. Clearly, we want to avoid this unpleasant situation. The only possibility is to weigh the piggy-bank and try to guess how many coins are inside. Assume that we are able to determine the weight of the pig exactly and that we know the weights of all coins of a given currency. Then there is some minimum amount of money in the piggy-bank that we can guarantee. Your task is to find out this worst case and determine the minimum amount of cash inside the piggy-bank. We need your help. No more prematurely broken pigs!
Input
Output
Sample Input
3
10 110
2
1 1
30 50
10 110
2
1 1
50 30
1 6
2
10 3
20 4
Sample Output
The minimum amount of money in the piggy-bank is 60.
The minimum amount of money in the piggy-bank is 100.
This is impossible. 思路:完全背包问题,dp[i][j]表示前i种硬币,重量为j时达到的最小值,考虑最直观情况,dp[i][j]=min(dp[i-1][j-k*w]+k*c)(0<=k<=j/w),但此式在计算时有重复,例如在计算dp[i][j-w]时候,计算了dp[i-1][j-w-n*w]+n*c(1<=n<=(j/w)-1),也就是当1<=k时,以此类推,计算dp[i][j]时候就只需要算min(dp[i-1][j],dp[i][j-w])即可,相当于dp[i][j-w]已经把1<=k的答案算出来了,再用滚动数组优化即可
const int INF = 0x3f3f3f3f;
int dp[], w[], c[];
int main() {
    ios::sync_with_stdio(false), cin.tie();
    int T;
    cin >> T;
    while(T--) {
        int E, F, V, N;
        cin >> E >> F >> N;
        V = F - E;
        for(int i = ; i <= V; ++i) dp[i] = INF;
        for(int i = ; i <= N; ++i) cin >> c[i] >> w[i];
        for(int i = ; i <= N; ++i) {
            for(int j = w[i]; j <= V; ++j)
                dp[j] = min(dp[j], dp[j-w[i]]+c[i]);
        }
        if(dp[V] < INF) cout << "The minimum amount of money in the piggy-bank is " << dp[V] << ".\n";
        else cout << "This is impossible.\n";
    }
    return ;
}
Day9 - D - Piggy-Bank POJ - 1384的更多相关文章
- poj  1384 Piggy-Bank(全然背包)
		http://poj.org/problem?id=1384 Piggy-Bank Time Limit: 1000MS Memory Limit: 10000K Total Submissions: ... 
- POJ 1384 POJ 1384 Piggy-Bank(全然背包)
		链接:http://poj.org/problem?id=1384 Piggy-Bank Time Limit: 1000MS Memory Limit: 10000K Total Submissio ... 
- POJ 1384 Piggy-Bank (ZOJ 2014 Piggy-Bank) 完全背包
		POJ :http://poj.org/problem?id=1384 ZOJ:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode ... 
- POJ 1384  Intervals (区间差分约束,根据不等式建图,然后跑spfa)
		传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1384 Intervals Time Limit: 10000/5000 MS (Java/Others ... 
- poj 1384 Piggy-Bank(完全背包)
		Piggy-Bank Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 10830 Accepted: 5275 Descr ... 
- POJ 1384
		求猜存钱罐中至少有多少钱.容易知道金币总的重量,接着背包. #include<cstdio> #include<iostream> using namespace std; # ... 
- POJ 1384 Piggy-Bank 背包DP
		所谓的全然背包,就是说物品没有限制数量的. 怎么起个这么intimidating(吓人)的名字? 事实上和一般01背包没多少差别,只是数量能够无穷大,那么就能够利用一个物品累加到总容量结尾就能够了. ... 
- poj 1384完全背包
		题意:给出猪罐子的空质量和满质量,和n个硬币的价值和质量,求猪罐子刚好塞满的的最小价值. 思路:选择硬币,完全背包问题,塞满==初始化为无穷,求最小价值,min. 代码: #include<io ... 
- ACM Piggy Bank
		Problem Description Before ACM can do anything, a budget must be prepared and the necessary financia ... 
随机推荐
- Jmeter调度器小记
			jmeter的调度器中[持续时间(秒)]的优先级是高于[结束时间]和[启动时间]的 举例子: 前提:[循环次数]勾选[永远] 场景1:[持续时间(秒)]设置为120S,[启动时间]设置T+1min,[ ... 
- IoT协议LwM2M MQTT与CoAP
			IoT协议LwM2M MQTT与CoAP 一.MQTT 1.概述: MQTT(Message Queuing Telemetry Transport,消息队列遥测传输)是IBM开发的一个即时通讯协议, ... 
- idea使用vue项目
			https://blog.csdn.net/qq_42564846/article/details/82688266 
- Vue——前端生成二维码
			与后端生成二维码相比,前端生成二维码更具有灵活性,下面就介绍两种前端生成二维码的方式,两种方式相比之下,vue-qr比qrcode多了一个再中间添加logo的功能. 方式一:qrcode npm np ... 
- WLC-Download 3-party CA to WLC
			一.基础准备 为了创建和导入第三方SSL-certificate你需要做如下准备:1.一个WLC(随着版本的不同,可能需要准备的也不同)这里以7.0.98版本为例.2.一个外部的证书颁发机构(Cert ... 
- 验证码 倒计时 vue  操作对象
			//html <input type="number" v-model="phoneNumber" placeholder="请输入手机号&qu ... 
- Android Studio 使用入门及问题汇总
			声明:转载自http://blog.csdn.net/wei_chong_chong/article/details/56280383 之前一直用eclipse+adt做Android开发.曾经尝试使 ... 
- iOS 根据域名查询 IP 地址
			在 iOS 开发中,如果需要知道网站的 IP 地址: #include <netdb.h> #include <arpa/inet.h> NSString *webSiteSt ... 
- 设计模式课程 设计模式精讲 3-10 里氏替换原则coding
			1 代码演练 1.1 继承关系判别(是否是真正意义的继承) 1.2 入参控制 1.3 出参控制 1 代码演练 1.1 继承关系判别(是否是真正意义的继承)(其实我觉得这个例子有点牵强) 1.1.1 反 ... 
- 神奇的 SQL 之 联表细节 → MySQL JOIN 的执行过程
			问题背景 对于 MySQL 的 JOIN,不知道大家有没有去想过他的执行流程,亦或有没有怀疑过自己的理解(自信满满的自我认为!):如果大家不知道怎么检验,可以试着回答如下的问题 驱动表的选择 MySQ ... 
