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 ...
随机推荐
- [原创] 使用rpi + crontab + git 定时向bitbucket 推送 照片
#前提条件,你得有一个bitbucket的帐户 1.定时启动脚本代码 使用的是crontab Cronfile 内容如下: 此文件的意思是,每隔10分钟,就运行一次 /home/pi/Rpi_uplo ...
- strategy pattern
- UVA How Big Is It?
题目例如以下: How Big Is It? Ian's going to California, and he has to pack his things, including hiscolle ...
- poj 3074 Sudoku(Dancing Links)
Sudoku Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 8152 Accepted: 2862 Descriptio ...
- HDU 1874 畅通公程续 (最短路 水)
Problem Description 某省自从实行了非常多年的畅通project计划后,最终修建了非常多路.只是路多了也不好,每次要从一个城镇到还有一个城镇时,都有很多种道路方案能够选择,而某些方案 ...
- 数据收集程序一般建筑(C++ ACE达到)
数据收集程序一般功能 经socket数据的接收的另一侧.端方能够访问智能电表采集器,你可曾与计算机之间的通信的通信协议(你良好的一致性是谁client,谁是服务端,即数据流) 为收集程序要求 可扩展: ...
- javascript的位操作、整数、二进制
位与(x&y):对操作数进行二进制与的操作,如果两个操作数的某一位两个都为1,将对应的结果位设为1. 0x0007 & 0x0003 = 0x0003 \ 一个小型年老棕色的狗:64 ...
- dwz 照片回头处理
我的要求.要选择封面文章,回头一看,实现,查找回头功能bringBack代码中发现的,它们朝着input 标签处理,所以img总是标签不能显示,这么dwz源所做的更改,于dwz.databases.j ...
- ACdream: ACfun
ACfun Time Limit: 2000/1000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Others) SubmitStatisti ...
- C#设计及其UML(反向工程)
OOP之C#设计及其UML(反向工程) 现在总结一下C#类关键字(virtual.abstract.override.new.sealed)的使用(以C#代码体现),并再次熟悉一下OOP思想,使用 ...