度度熊与邪恶大魔王

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 251    Accepted Submission(s): 125

Problem Description
度度熊为了拯救可爱的公主,于是与邪恶大魔王战斗起来。
邪恶大魔王的麾下有n个怪兽,每个怪兽有a[i]的生命值,以及b[i]的防御力。
度度熊一共拥有m种攻击方式,第i种攻击方式,需要消耗k[i]的晶石,造成p[i]点伤害。
当然,如果度度熊使用第i个技能打在第j个怪兽上面的话,会使得第j个怪兽的生命值减少p[i]-b[j],当然如果伤害小于防御,那么攻击就不会奏效。
如果怪兽的生命值降为0或以下,那么怪兽就会被消灭。
当然每个技能都可以使用无限次。
请问度度熊最少携带多少晶石,就可以消灭所有的怪兽。
Input
本题包含若干组测试数据。
第一行两个整数n,m,表示有n个怪兽,m种技能。
接下来n行,每行两个整数,a[i],b[i],分别表示怪兽的生命值和防御力。
再接下来m行,每行两个整数k[i]和p[i],分别表示技能的消耗晶石数目和技能的伤害值。
数据范围:
1<=n<=100000
1<=m<=1000
1<=a[i]<=1000
0<=b[i]<=10
0<=k[i]<=100000
0<=p[i]<=1000
Output
对于每组测试数据,输出最小的晶石消耗数量,如果不能击败所有的怪兽,输出-1
Sample Input
1 2
3 5
7 10
6 8
1 2
3 5
10 7
8 6
Sample Output
6
18
Source
 
背包
dp[i][j]表示消灭i生命值j防御力的怪物花费的最少晶石
由题目可得  怪物的防御力0-10  所以我们枚举怪物的防御 然后进行完全背包  就可以得到结果
 #include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cctype>
#include<cmath>
#include<cstring>
#include<map>
#include<set>
#include<queue>
#include<vector>
#include<algorithm>
#include<string>
#define ll long long
#define eps 1e-10
#define LL unsigned long long
using namespace std;
const int INF=0x3f3f3f3f;
const int N=+;
const int mod=;
int a[N],b[N];
struct node{
int k,p;
}val[N];
ll dp[][];
ll minn[N];
bool cmp(node a,node b)
{
return a.k-a.p<b.k-b.p;
}
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF)
{
int maxx1=;
int maxx2=;
memset(minn,INF,sizeof(minn));
for(int i=;i<n;i++){
scanf("%d%d",&a[i],&b[i]);
maxx1=max(maxx1,b[i]);
}
for(int i=;i<m;i++){
scanf("%d%d",&val[i].k,&val[i].p);
maxx2=max(maxx2,val[i].p);
}
for(int i=;i<;i++)
for(int j=;j<;j++)dp[i][j]=1e10;
for(int j=;j<=;j++)dp[][j]=;
sort(val,val+m,cmp);
for(int k=;k<=;k++)
for(int i=;i<m;i++)
for(int j=;j<=;j++){
if(j-val[i].p+k<=)dp[j][k]=min((ll)val[i].k,dp[j][k]);
else
dp[j][k]=min(dp[j][k],dp[j-val[i].p+k][k]+val[i].k); }
ll ans=;
for(int i=;i<n;i++){
ans=ans+dp[a[i]][b[i]];
}
if(maxx2<=maxx1)cout<<-<<endl;
else
printf("%I64d\n",ans);
}
return ;
}
 

最新文章

  1. JS技巧
  2. Codeforces Round #252 (Div. 2) A - Valera and Antique Items
  3. iOS Container View Controller
  4. 利用doxygen提高源代码阅读效率
  5. 《Gulp 入门指南》 : 使用 gulp 压缩 JS
  6. 【python自动化第六篇:面向对象】
  7. .NET获取机器信息
  8. Socket 学习(三).4 UDP 穿透 客户端与客户端连接
  9. java程序使用memcached
  10. MySQL定时逻辑备份
  11. SVN如何commit(提交)项目代码
  12. Hive操作语句实例讲解(帮助你了解 桶 bucket)
  13. c/c++程序连接mysql
  14. 腾讯地图打开地图选取位置 withMap
  15. 微软BI SSIS 2012 ETL 控件与案例精讲面试 200 问(SSIS 面试题,ETL 面试题)
  16. vmware中如何检查cpu的使用状况-一个考题引发的思考
  17. UVa 1620 懒惰的苏珊(逆序数)
  18. NodeJS-001-Nodejs学习文档整理(转-出自http://www.cnblogs.com/xucheng)
  19. Excel ALT+小键盘的妙用
  20. [EffectiveC++]item22:Declare data members private

热门文章

  1. PHP基础知识测试题及解析
  2. x264
  3. 关于类似vue-cli 脚手架
  4. CSS——display:flex
  5. (一)Python 学习第一天--基础知识,列表
  6. CSS居中布局方案
  7. css中有些属性的前面会加上“*”或“_(兼容IE浏览器)
  8. mt_rand()和rand()两者的区别
  9. Day 13 进程和线程
  10. 【Redis】一、Redis简介及五种数据类型