HDU 2159 FATE (完全背包+有限尚需时日)()双费背包
FATE
xhd还说了他最多仅仅杀s仅仅怪。请问他能升掉这最后一级吗?
接下来输入k行数据。
每行数据输入两个正整数a,b(0 < a,b < 20);分别表示杀掉一仅仅这样的怪xhd会得到的经验值和会减掉的忍耐度。(每种怪都有无数个)
10 10 1 10
1 1
10 10 1 9
1 1
9 10 2 10
1 1
2 2
0
-1
1
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<cctype>
#define INF 0x3f3f3f3f
#define maxn 100+10 using namespace std; int cost[maxn],val[maxn],cnt[maxn];
int dp[maxn];
int n,m,k,s; void completepack()
{
memset(cnt,0,sizeof cnt);
memset(dp,0,sizeof(dp));
for(int i=1;i<=k;i++)
for(int j=cost[i];j<=m;j++)
{
if(dp[j]<dp[j-cost[i]]+val[i])
{
cnt[j]=cnt[j-cost[i]]+1; //计数数组
dp[j]=dp[j-cost[i]]+val[i];
}
}
} int main()
{
while(scanf("%d%d%d%d",&n,&m,&k,&s)!=EOF)
{
int ok=1;
for(int i=1;i<=k;i++)
scanf("%d%d",val+i,cost+i);
completepack();
for(int i=0;i<=m;i++) //这里貌似是题目的bug,经验能够为0.
{
if(dp[i]>=n&&cnt[i]<=s)
{
printf("%d\n",m-i);
ok=0;
break;
} }
if(ok)
printf("-1\n");
} return 0;
}
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 100+10
using namespace std; int cost[maxn],val[maxn],num[maxn],dp[maxn][maxn];
int n,m,k,s; void twocost()
{
memset(dp,0,sizeof dp);
for(int i=1;i<=k;i++)
for(int t=1;t<=s;t++)
for(int j=cost[i];j<=m;j++)
{
dp[j][t]=max(dp[j][t],dp[j-cost[i]][t-1]+val[i]);
}
} int main()
{
int minn;
while(scanf("%d%d%d%d",&n,&m,&k,&s) != EOF)
{
for(int i = 1; i <= k; i++)
scanf("%d%d",&val[i],&cost[i]);
twocost(); if(dp[m][s] < n)
printf("-1\n");
else
{
minn = m;
for(int i = 0; i <= s; i++)
{
for(int j = 0; j <=m; j++)
if(dp[j][i] >= n&&j < minn)
minn = j;
}
printf("%d\n",m - minn);
} } }
版权声明:本文博客原创文章,博客,未经同意,不得转载。
HDU 2159 FATE (完全背包+有限尚需时日)()双费背包的更多相关文章
- HDOJ(HDU).2159 FATE (DP 带个数限制的完全背包)
HDOJ(HDU).2159 FATE (DP 带个数限制的完全背包) 题意分析 与普通的完全背包大同小异,区别就在于多了一个个数限制,那么在普通的完全背包的基础上,增加一维,表示个数.同时for循环 ...
- HDU 2159 FATE(二维费用背包)
FATE Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- HDU 2159 FATE 完全背包
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2159 FATE Time Limit: 2000/1000 MS (Java/Others)Memo ...
- HDU 2159 FATE (二维完全背包
FATE http://acm.hdu.edu.cn/showproblem.php?pid=2159 Problem Description 最近xhd正在玩一款叫做FATE的游戏,为了得到极品装备 ...
- HDU 2159 FATE (二维背包)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2159 解题报告:这题实际上是一个二维的背包问题,也可以由01背包扩展而来,01背包用一维数组,可想而知 ...
- HDU 2159 FATE(全然背包+二维费用背包)
FATE Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Submi ...
- hdu 2159 FATE (二维完全背包)
链接:http://acm.hdu.edu.cn/showproblem.php?pid=2159 思路: dp[j][k] 代表消耗耐久度j,干掉k个敌人获得的经验值. 状态转移方程为: dp[j] ...
- hdu 2159 FATE (二维完全背包)
Problem Description 最近xhd正在玩一款叫做FATE的游戏,为了得到极品装备,xhd在不停的杀怪做任务.久而久之xhd开始对杀怪产生的厌恶感,但又不得不通过杀怪来升完这最后一级.现 ...
- HDU 2159 FATE(二维全然背包)
中文题目就不用解释了 就是裸的二维全然背包 d[i][j]表示消耗i忍耐杀j个怪最多可获得的经验 然后就用全然背包来做了 二维背包背包只是是多了一重循环 <span style=&quo ...
随机推荐
- centos安装和卸载软件
==如何卸载: 1.打开一个SHELL终端 2.因为Linux下的软件名都包括版本号,所以卸载前最好先确定这个软件的完整名称. 查找RPM包软件:rpm -qa ×××* 注意:×××指软件名称开头的 ...
- zerglurker的c语言教程006——第一功能
行,以往的经验教训后,.成员main性能.变数.命名等基本概念应该有一个初步的了解 下面,我们就可以开始我们自己的第一个定义的函数. 仿照头等舱.操作的第二个教训.添加一个新的项目的解决方案Lessi ...
- mtk硬件项目开始关闭蓝牙功能:mtk 硬件ScanCode和keycode应用演示示例
项目要求:该项目因为没有使用android5.0,导致启动bluetooth的蓝牙audio slave功能必须使用第三方模组,该第三方模组,启动是通过android主板通过GPIO控制.UI界面是通 ...
- 利用HttpOnly来防御xss攻击
xss的概念就不用多说了,它的危害是极大的,这就意味着一旦你的站点出现xss漏洞,就能够运行随意的js代码,最可怕的是攻击者利用js获取cookie或者session劫持,假设这里面包括了大量敏感信息 ...
- 【Linux探索之旅】第一部分第五课:Unity桌面,人生若只如初见
内容简介 1.第一部分第五课:Unity桌面,人生若只如初见 2.第一部分第六课预告:Linux如何安装在虚拟机中 Unity桌面,人生若只如初见 不容易啊,经过了前几课的学习,我们认识了Linux是 ...
- Visual Studio 连接不上NuGet 官方程序包源的解决办法
修改dns 即可
- http协议和web本质(转)
当你在浏览器地址栏敲入“http://www.cnblogs.com/”,然后猛按回车,呈现在你面前的,将是博客园的首页了(这真是废话,你会认为这是理所当然的).作为一个开发者,尤其是web开发人员, ...
- ios崩溃日志1
Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Could not loa ...
- HDU 2454 Degree Sequence of Graph G(Havel定理 推断一个简单图的存在)
主题链接:pid=2454">http://acm.hdu.edu.cn/showproblem.php?pid=2454 Problem Description Wang Haiya ...
- Cocos2d-x 3.2 Lua演示样本CocosDenshionTest(音频测试)
Cocos2d-x 3.2 Lua演示样本CocosDenshionTest(音频测试) 本篇博客介绍Cocos2d-x 3.2中Lua演示样例的音频測试.Cocos2d-x使用SimpleAudi ...