度度熊与邪恶大魔王

 

链接:http://acm.hdu.edu.cn/showproblem.php?pid=6082

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<=1000001<=m<=10001<=a[i]<=10000<=b[i]<=100<=k[i]<=1000000<=p[i]<=1000Output
对于每组测试数据,输出最小的晶石消耗数量,如果不能击败所有的怪兽,输出-1Sample Input
1 2
3 5
7 10
6 8
1 2
3 5
10 7
8 6Sample Output
6
18Source
2017"百度之星"程序设计大赛 - 资格赛
题干

 

#include<cstdio>
#include<cstring>
#include<algorithm>
#define LL long long
using namespace std;
const LL INF=1e18+7;
LL n,m,f[155][5507];
LL maxp,max1,max2,ans,mn;
LL a[100007],b[100007],v[100007],p[100007];
void first(){for(int i=0;i<=max2;i++)for(int j=1;j<=max1+maxp;j++)f[i][j]=INF;for(int k=0;k<=max2;k++)for(int i=1;i<=m;i++){LL now=p[i]-(LL)k;if(now<=0) continue;for(int j=1;j<=maxp+max1;j++){if(j-now>=0) f[k][j]=min(f[k][j],f[k][j-now]+v[i]);else f[k][j]=min(f[k][j],v[i]);}}
}
int main()
{while(scanf("%lld %lld",&n,&m)!=EOF){maxp=max1=max2=ans=mn=0;for(int i=1;i<=n;i++){scanf("%lld%lld",&a[i],&b[i]),max1=max(a[i],max1),max2=max(max2,b[i]);}for(int i=1;i<=m;i++){scanf("%lld%lld",&v[i],&p[i]);maxp=max(maxp,p[i]);}if(max2>=maxp){printf("-1\n");continue;}first();for(int i=1;i<=n;i++)            ans+=f[b[i]][a[i]];printf("%lld\n",ans);}return 0;
}
代码

 

数据怎么大,有像背包(有递推性质),那就dp吧。

f[i][j]表示要杀掉防御为i,生命为j的怪兽需要的水晶。

dp时要注意:如果不能破防,就不要用该技能啦。

转载于:https://www.cnblogs.com/CLGYPYJ/p/7390466.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/428880.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Codeforces Round #719 (A-C)

第一题题意&#xff1a;就是不能回去&#xff1a; #include<iostream> using namespace std; int main() {int t;cin>>t;while (t--){int n,ch[1001]{0};cin>>n;string str;cin>>str;bool flag true;ch[str[0]];for (int i1;i<n;i){if (str[i]!st…

html加注算法源码,200种加密算法(源码)

【实例简介】【实例截图】【核心代码】3way.cpp3way.h3wayval.datalgebra.cppalgebra.hasn.cppasn.hbase64.cppbase64.hbench.cppbench.hbfinit.cppblowfish.cppblowfish.hblum1024.datblum2048.datblum512.datblumgold.cppblumgold.hblumshub.cppblumshub.hcast.cppcast.hcast…

ibm量子计算机科学家,重磅!IBM发布全球首个独立商用量子计算机

原标题&#xff1a;【重磅】IBM发布全球首个独立商用量子计算机雷锋网消息&#xff0c;全球的科技巨头都在量子计算上投入了大量资源。值得关注的是&#xff0c;在2019 CES上&#xff0c;IBM宣布推出IBM Q System One&#xff0c;该系统是世界上首个专为科学和商业用途设计的集…

1012 数字分类 (20 分)(C语言实现)

帮同学改的代码&#xff0c;简单易懂因为他是刚开始做 的写法&#xff1a; #include <stdio.h> #define MAX 10001 int main() {int i, n;int sum1 0;int A1 0, A2 0, A3 0, A4 0;int a[MAX];scanf("%d", &n);for (i 0; i < n; i){scanf("%…

第三次个人赛题目2 【多项式输出格式】

问题 B: 此题乃神题&#xff0c;劝你别做 时间限制: 1 Sec 内存限制: 128 MB提交: 138 解决: 8[提交][状态][讨论版]题目描写叙述 声明&#xff1a;这道题没有涉及不论什么算法&#xff01;给定函数f (1) (2) * b (3) * c (4) * d (5)。 输入 输入数据有多组。 每组数据…

html5干货,干货:详解HTML5中常见的五大全局属性

HTML5中新增了“全部属性”的概念。所谓全局属性它是指可以对任何元素都可以使用的属性&#xff0c;今天为大家详细介绍三种常见的全局属性。contentEditable属性contentEditable是由微软开发。被其他浏览器反编译并投入应用的一个全局属性。它的主要功能是是否允许用户编辑元素…

用C语言模拟栈(简单实现)

//C语言模拟栈&#xff0c;简单实现 #include <stdio.h> #include <stdlib.h> typedef struct Node node; struct Node {int data;node *next; }; int quchu(node *p) //取出栈中的数 {if (p->next NULL)return -1;else{int x p->next->data;return x;}…

计算机网络技术教材多少钱,计算机网络技术课程标准教材.doc

《计算机网络技术》课程标准?为了规范计算机网络技术课程的教学&#xff0c;促进该课程教学质量的不断提高&#xff0c;保证计算机网络专业人才培养规格&#xff0c;特制定本课程的标准。本标准包括课程的性质与课程定位的定性描述、课程标准的设计思路、课程目标、课程内容标…

7-13 部落 (25 分)

在一个社区里&#xff0c;每个人都有自己的小圈子&#xff0c;还可能同时属于很多不同的朋友圈。我们认为朋友的朋友都算在一个部落里&#xff0c;于是要请你统计一下&#xff0c;在一个给定社区中&#xff0c;到底有多少个互不相交的部落&#xff1f;并且检查任意两个人是否属…

CSS常用的选择器和优先级的权重问题

CSS注释 CSS修改页面中的所有标签&#xff0c;必须借助选择器选中。选择器中&#xff0c;可以写多对CSS属性&#xff0c;用{}包裹&#xff1b;每个属性名与属性值之间用:分隔&#xff0c;多对属性之间&#xff0c;必须用;来分隔选择器{ 属性1:属性值1; 属性2:属性值2; 【选择器…

江阳职高计算机应用教改实验,计算机应用课程教改模式

掌握基本的计算机操作技能几乎成为当前社会每位劳动者的必备知识。在此情况下&#xff0c;以就业为根本导向的高职院校更应当注重学生的计算机基本教学。“计算机应用基础”课程教学也要不断与与时俱进&#xff0c;这样在才能适应社会对人才的全新要求。本文主要就高职院校“计…

memset和fill

C : memset 用法:memset(a,0,sizeof(a)); C fill用法&#xff1a;fill(ch,chn,0); 二维数组&#xff1a;fill&#xff08;ch[0],ch[0]mn,0);

转 list三种遍历效率

第一种&#xff1a;迭代器遍历for(Iterator<String> it list.iterator(); it.hasNext(); ) { .... } 这种方式在循环执行过程中会进行数据锁定&#xff0c;性能稍差&#xff0c;同时如果你想在循环过程中去掉某个元素&#xff0c;只能调用it.re…

7-9 六度空间 (30 分) C++实现

7-9 六度空间 (30 分) “六度空间”理论又称作“六度分隔&#xff08;Six Degrees of Separation&#xff09;”理论。这个理论可以通俗地阐述为&#xff1a;“你和任何一个陌生人之间所间隔的人不会超过六个&#xff0c;也就是说&#xff0c;最多通过五个人你就能够认识任何一…

有关计算机组成原理知识的论文,关于计算机组成原理的论文_计算机组成原理_图灵机的组成...

懂计算机组成原理的朋友进&#xff0c;帮帮我啊&#xff01;2演示《闪速存储器及技术》。首先是多媒体的组成&#xff0c;图声字&#xff0c;二是计算机的组成&#xff0c;主板&#xff0c;CPU&#xff0c;内存。三电脑读文件的过程 CPU将多媒体文件有硬盘调入内存&#xff0c;…

如何开发一个异常检测系统:异常检测 vs 监督学习

异常检测算法先是将一些正常的样本做为无标签样本来学习模型p(x),即评估参数&#xff0c;然后用学习到的模型在交叉验证集上通过F1值来选择表现最好的ε的值&#xff0c;然后在测试集上进行算法的评估。这儿用到了带有标签的数据&#xff0c;那么为什么不直接用监督学习对y1和y…

浙江省高等学校计算机等级考试有什么用,06秋年秋浙江省高等学校计算机等级考试试卷(三级数据库技术及应用)...

2006年秋浙江省高等学校(三级网络技术)试题1判断题用√和表示对和错(每小题1分&#xff0c;共10分)1&#xff0e;WWW是基于客户机和超文本技术建立的&#xff0c;其工作方式是客户机/服务器模式。T(1)2&#xff0e;计算机网络中信息的传输速率的单位是帧/秒。F(2)3&#xff0e;…

7-6 列出连通集 (25 分)(C语言实现)

给定一个有N个顶点和E条边的无向图&#xff0c;请用DFS和BFS分别列出其所有的连通集。假设顶点从0到N−1编号。进行搜索时&#xff0c;假设我们总是从编号最小的顶点出发&#xff0c;按编号递增的顺序访问邻接点。 输入格式: 输入第1行给出2个整数N(0<N≤10)和E&#xff0c…

KVM--安装及初步使用

KVM是Kernel-based Virtual Machine的简称,是一个开源的虚拟化模块,今天我将在CentOS7的操作系统上安装KVM,以下是我的安装步骤. 一.环境信息 系统: CentOS 7.2 IP: 10.0.0.12/24 在虚拟机安装时,需要启用CPU的虚拟化功能 二. KVM安装步骤 1. 安装qemu-kvm和libvirt [rootkvm-…

微机化远动系统与计算机网络,远动技术教案_第3章_微机监控系统数据通信网络结构及原理.pdf...

Generated by Foxit PDF Creator © Foxit SoftwareFor evaluation only.第三章数据通信网络结构及原理远动监控系统信息传输及网络通信技术主讲&#xff1a;申惠华东交通大学电气与电子工程学院Generated by Foxit PDF Creator © Foxit SoftwareFor evaluation only.…