2017"百度之星"程序设计大赛 - 资格赛-度度熊与邪恶大魔王(dp+后缀最小值)
思路:由于防御和血量的范围很小,所以暴力枚举出对于每种防御造成的每种伤害所需的最小花费,最后只需在伤害大于等于血量的情况下再找到最小花费(这个只需要后缀最小值预处理一下就可以了)
状态:dp[i][j]表示对防御为i的怪兽造成伤害为j的所需最小晶石花费。
状态转移方程:dp[i][j]=min(dp[i][j],dp[i][j-t])(t表示每种技能造成的伤害,t=p-i,t>0)
代码1:
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define ls rt<<1,l,m
#define rs rt<<1|1,m+1,r
#define pb push_back
#define mem(a,b) memset((a),(b),sizeof(a))
const int INF=0x3f3f3f3f;
const int N=2e3+;//必须开2e3,因为造成的伤害是大于等于血量的(1000+1000)
const int M=1e5+;
int dp[][N];
int a[M],b[M],k[N],p[N];
int main()
{
int n,m;
while(~scanf("%d%d",&n,&m))
{
for(int i=;i<n;i++)
{
scanf("%d%d",&a[i],&b[i]);
}
for(int i=;i<m;i++)
{
scanf("%d%d",&k[i],&p[i]);
}
mem(dp,INF);
for(int i=;i<=;i++)
{
dp[i][]=;//所有状态的初始状态都是dp[i][0]
for(int j=;j<m;j++)
{
int t=p[j]-i;
if(t<=)continue;
for(int l=t;l<N;l++)
{
dp[i][l]=min(dp[i][l-t]+k[j],dp[i][l]);
}
}
for(int j=N-;j>=;j--)
{
dp[i][j]=min(dp[i][j+],dp[i][j]);//求一下后缀最小值
}
}
ll ans=;
bool flag=false;
for(int i=;i<n;i++)
{
ans+=dp[b[i]][a[i]];
if(dp[b[i]][a[i]]==INF)flag=true;//等于INF表示不存在这样的最小花费
}
if(flag)cout<<-<<endl;
else cout<<ans<<endl;
}
return ;
}
代码2:
上面那个代码是先枚举技能再枚举伤害的,这个代码是先枚举伤害再枚举技能的,相比而言这个要慢一些,因为上面那个枚举技能时就知道伤害的范围(下界即t),相当于下面这个代码剪过枝了。
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define ls rt<<1,l,m
#define rs rt<<1|1,m+1,r
#define pb push_back
#define mem(a,b) memset((a),(b),sizeof(a))
const int INF=0x3f3f3f3f;
const int N=2e3+;
const int M=1e5+;
int dp[][N];
int a[M],b[M],k[N],p[N];
int main()
{
int n,m;
while(~scanf("%d%d",&n,&m))
{
for(int i=;i<n;i++)
{
scanf("%d%d",&a[i],&b[i]);
}
for(int i=;i<m;i++)
{
scanf("%d%d",&k[i],&p[i]);
}
mem(dp,INF);
for(int i=;i<=;i++)
{
dp[i][]=;
for(int j=;j<N;j++)
{
for(int l=;l<m;l++)
{
int t=p[l]-i;
if(t<=||t>j)continue;
dp[i][j]=min(dp[i][j-t]+k[l],dp[i][j]);
}
}
for(int j=N-;j>=;j--)
{
dp[i][j]=min(dp[i][j+],dp[i][j]);
}
}
ll ans=;
bool flag=false;
for(int i=;i<n;i++)
{
ans+=dp[b[i]][a[i]];
if(dp[b[i]][a[i]]==INF)flag=true;
}
if(flag)cout<<-<<endl;
else cout<<ans<<endl;
}
return ;
}
2017"百度之星"程序设计大赛 - 资格赛-度度熊与邪恶大魔王(dp+后缀最小值)的更多相关文章
- 2017"百度之星"程序设计大赛 - 资格赛 度度熊的王国战略
度度熊的王国战略 度度熊国王率领着喵哈哈族的勇士,准备进攻哗啦啦族. 哗啦啦族是一个强悍的民族,里面有充满智慧的谋士,拥有无穷力量的战士. 所以这一场战争,将会十分艰难. 为了更好的进攻哗啦啦族,度度 ...
- hdu 6082 度度熊与邪恶大魔王(2017"百度之星"程序设计大赛 - 资格赛 )
度度熊与邪恶大魔王 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- [SinGuLaRiTy] 2017 百度之星程序设计大赛-资格赛
[SinGuLaRiTy-1034] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 度度熊保护村庄 Time Limit: 2000/10 ...
- 2017"百度之星"程序设计大赛 - 资格赛【1001 Floyd求最小环 1002 歪解(并查集),1003 完全背包 1004 01背包 1005 打表找规律+卡特兰数】
度度熊保护村庄 Accepts: 13 Submissions: 488 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/3276 ...
- 2017"百度之星"程序设计大赛 - 资格赛
度度熊与邪恶大魔王 Accepts: 3666 Submissions: 22474 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: ...
- 2017"百度之星"程序设计大赛 - 资格赛 1002 度度熊的王国战略
全局最小割 Stoer-Wagner (SW算法)优化 优化吃藕了,感谢放宽时限,感谢平板电视 (pb_ds) #include <iostream> #include <cstdi ...
- 2017"百度之星"程序设计大赛 - 资格赛 寻找母串
Problem Description 对于一个串S,当它同时满足如下条件时,它就是一个01偏串: 1.只由0和1两种符组成: 2.在S的每一个前缀中,0的个数不超过1的个数: 3.S中0的个数和1的 ...
- HDU 6118 度度熊的交易计划 【最小费用最大流】 (2017"百度之星"程序设计大赛 - 初赛(B))
度度熊的交易计划 Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- HDU 6119 小小粉丝度度熊 【预处理+尺取法】(2017"百度之星"程序设计大赛 - 初赛(B))
小小粉丝度度熊 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Sub ...
随机推荐
- Linux编译安装中configure、make和make install各自的作用
这些都是典型的使用GNU的AUTOCONF和AUTOMAKE产生的程序的安装步骤. ./configure是用来检测你的安装平台的目标特征的.比如它会检测你是不是有CC或GCC,并不是需要CC或G ...
- Django初级手册6-静态文件
用Django加载外部文件 在Django中iamges,JS或者CSS通称为static文件 定制APP的外观 一般放在应用目录下的static/polls/目录下,下为polls/static/p ...
- Lower Power with CPF(二)
CPF文件可以有两种组织方式:Flat CPF file or Hierarchical CPF file. 由于在大型的SoC设计中,一般都采用Hierarchical的形式,所以本文主要按这个方式 ...
- 使用IP连接SQL SERVER或者配置为连接字符串失败
使用IP连接SQL SERVER或者配置为连接字符串失败 情景一:当在webconfig文件中使用 <add key="ConnectionString" value=& ...
- Python: ValueError: too many values to unpack
eg1: >>>a,b=(1,2,3) Traceback (most recent call last): File "<stdin>",line ...
- idea 上搭建 Mybatis 逆向工程
网盘地址:https://pan.baidu.com/s/1VAILpdgQbFk9t89eEv_nWQ 提取码:xdyc
- 【运维技术】Nexus私服安装配置常用问题
maven私服安装配置 软件安装及基本配置 安装配置 # 安装jdk,参考其他教程 mkdir -p /app/nexus2 # 创建目录 wget https://download.sonatype ...
- 02: Redis缓存系统
目录: 1.1 在centos6.5中安装Redis 1.2 Redis的简介及两种基本操作 1.3 Redis对string操作(第一类) 1.4 redis对Hash操作,字典格式(第二类) 1. ...
- 小工具:使用Python自动生成MD风格链接
很久之前我在Github上搞了一个LeetCode的仓库,但一直没怎么维护.最近发现自己刷了不少LC的题目了,想搬运到这个仓库上. 玩Github最重要的当然是写README了,MD的逼格决定了项目牛 ...
- springboot整合mybatis将sql打印到日志(转)
在前台请求数据的时候,sql语句一直都是打印到控制台的,有一个想法就是想让它打印到日志里,该如何做呢? 见下面的mybatis配置文件: <?xml version="1.0" ...