HDU 1494 题解(DP)
题面:
跑跑卡丁车
Problem Description
跑跑卡丁车是时下一款流行的网络休闲游戏,你可以在这虚拟的世界里体验驾驶的乐趣。这款游戏的特别之处是你可以通过漂移来获得一种
加速卡,用这种加速卡可以在有限的时间里提高你的速度。为了使问题简单化,我们假设一个赛道分为L段,并且给你通过每段赛道的普通耗时Ai和用加速卡的耗时Bi。加速卡的获得机制是:普通行驶的情况下,每通过1段赛道,可以获得20%的能量(N2O).能量集满后获得一个加速卡(同时能量清0).加速卡最多可以储存2个,也就是说当你有2个加速卡而能量再次集满,那么能量清零但得不到加速卡。一个加速卡只能维持一段赛道,游戏开始时没有加速卡。
问题是,跑完n圈最少用时为多少?
Input
每组输入数据有3行,第一行有2个整数L,N分别表示一圈赛道分为L段和有N圈赛道,接下来两行分别有L个整数Ai和Bi
(Ai > Bi).
Output
对于每组输入数据,输出一个整数表示最少的用时.
Sample Input
18 1
9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9 9
8 8 8 8 8 8 8 8 8 8 8 8 8 8 1 1 8 8
Sample Output
145
对于sample这组数据,你可以先在普通情况下行驶前14段,这时你有2个加速卡以及80%的能量(N2O).在第15和16段用掉2个加速卡,通过第
17段赛道后又可以得到一个加速卡,在第18段赛道使用.
分析:
一开始这道题可能看起来像贪心,但观察数据范围可知如果是贪心的话数据量不可能这么小,故采用DP的做法
划分子问题&确定状态:
子问题:走到某个路段,有一定能量值时的时间
子状态:很容易想到走到第几个路段,以及该路段的能量可以作为子状态,但是能量值为小数,而double类型不能作为dp数组的下标
考虑到能量值每次增加20%,我们以20%为单位“1”,这样每一个能量卡能量值为5,能量槽最多存的能量为4,所以总能量最多为14
因此我们只要用一个二维数组来存储状态即可确定决策&写出状态转移方程
我们定义dp[i][j] 表示走完第i段,能量值为j时的最短时间
t[i].a表示第i段正常通过的时间,t[i].b表示第i段非正常通过的时间
i显然是由i-1转移过来,但是j呢?
我们对j进行分类讨论:
当j=0j=0时,即能量恰好为0时肯定刚刚使用了一个加速卡,能量被清0(如果是已有2个加速卡,能量肯定大于10)
因此dp[i][j]=dp[i-1][5]+t[i].b
当0<j<100<j<10时 有两种可能,之前可能消耗了一个加速卡或者没消耗加速卡,因此dp[i][j]=min(dp[i-1][j-1]+t[i].a,dp[i-1][j+5]+t[i].b)
当j=10j=10时也有两种可能,之前没消耗加速卡或者已有两个加速卡而能量被清0,因此dp[i][j]=min(dp[i-1][j-1]+t[i].a,dp[i-1][14]+t[i].a)
当j>10j>10时只有一种可能,之前没消耗加速卡,因此dp[i][j]=dp[i-1][j-1]+t[i].a
将上述四种情况综合起来,便可以写出以下的状态转移方程:
dp[i][j]=dp[i][j]= ⎧⎩⎨⎪⎪⎪⎪⎪⎪dp[i−1][5]+t[i].b(j=0)min(dp[i−1][j−1]+t[i].a,dp[i−1][j+5]+t[i].b)(0<j<10)min(dp[i−1][j−1]+t[i].a,dp[i−1][14]+t[i].a)(j=10)dp[i−1][j−1]+t[i].a(j>10){dp[i−1][5]+t[i].b(j=0)min(dp[i−1][j−1]+t[i].a,dp[i−1][j+5]+t[i].b)(0<j<10)min(dp[i−1][j−1]+t[i].a,dp[i−1][14]+t[i].a)(j=10)dp[i−1][j−1]+t[i].a(j>10)
3.寻找边界条件
0<i<l×n0<i<l×n
0<j<150<j<15
但有一个细节需要注意:
for(int i=1;i<maxe;i++) dp[0][i]=INF;//注意dp[0][0]是0,其余是INF
代码:
#include<iostream>
#include<cstring>
#define maxl 105
#define maxn 105
#define maxe 15 //最大储存能量5*2+4=14
#define INF 99999999
using namespace std;
int dp[maxn*maxl][maxe];
struct node{
int a;
int b;
}tim[maxn*maxl];
int l,n,ans;
int main(){
while(cin>>l>>n){
for(int i=1;i<=l;i++) cin>>tim[i].a;
for(int i=1;i<=l;i++) cin>>tim[i].b;
tim[0]=tim[l];
for(int i=l+1;i<=l*n;i++) tim[i]=tim[i%l];//将1圈之后的段也赋值
memset(dp,0,sizeof(dp));
for(int i=1;i<maxe;i++) dp[0][i]=INF;//注意dp[0][0]是0
for(int i=1;i<=l*n;i++){
for(int j=0;j<maxe;j++){
if(j==0) dp[i][j]=dp[i-1][5]+tim[i].b;
else if(j<10) dp[i][j]=min(dp[i-1][j-1]+tim[i].a,dp[i-1][j+5]+tim[i].b);
else if(j==10) dp[i][j]=min(dp[i-1][j-1]+tim[i].a,dp[i-1][14]+tim[i].a);
else if(j>10) dp[i][j]=dp[i-1][j-1]+tim[i].a;
}
}
ans=INF;
for(int i=0;i<maxe;i++){
ans=min(ans,dp[l*n][i]);
}
cout<<ans<<endl;
}
return 0;
}
HDU 1494 题解(DP)的更多相关文章
- HDU 5945 题解(DP)(单调队列)
题面: Fxx and game Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 131072/65536 K (Java/Others) T ...
- HDU 1494 跑跑卡丁车 (DP)
题目链接 题意 : 中文题不详述. 思路 : sum = L*N 段,每走过一段如果不用加速卡的话,能量会增20%,将20%看作1,也就是说每涨到15就要变为10,所以最多是14才不浪费. dp[i] ...
- HDU 3401 Trade dp+单调队列优化
题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3401 Trade Time Limit: 2000/1000 MS (Java/Others)Mem ...
- B - Lawrence HDU - 2829 斜率dp dp转移方程不好写
B - Lawrence HDU - 2829 这个题目我觉得很难,难在这个dp方程不会写. 看了网上的题解,看了很久才理解这个dp转移方程 dp[i][j] 表示前面1~j 位并且以 j 结尾分成了 ...
- hdu 4123 树形DP+RMQ
http://acm.hdu.edu.cn/showproblem.php? pid=4123 Problem Description Bob wants to hold a race to enco ...
- hdu 4507 数位dp(求和,求平方和)
http://acm.hdu.edu.cn/showproblem.php?pid=4507 Problem Description 单身! 依旧单身! 吉哥依旧单身! DS级码农吉哥依旧单身! 所以 ...
- hdu 3709 数字dp(小思)
http://acm.hdu.edu.cn/showproblem.php?pid=3709 Problem Description A balanced number is a non-negati ...
- hdu 4352 数位dp + 状态压缩
XHXJ's LIS Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- hdu 4283 区间dp
You Are the One Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)T ...
随机推荐
- Django【第20篇】:Ajax
初始Ajax 一.Ajax准备知识:json 说起json,我们大家都了解,就是python中的json模块,那么json模块具体是什么呢?那我们现在详细的来说明一下 1.json(Javascrip ...
- Spring源码--Bean的管理总结(一)
前奏 最近看了一系列解析spring管理Bean的源码的文章,在这里总结下,方便日后复盘.文章地址https://www.cnblogs.com/CodeBear/p/10336704.html sp ...
- sql中count(1)和count(*)有区别吗
count(*) 对 innodb 而言,它需要把数据从磁盘中读取出来然后累计计数:而 MyISAM 引擎把一个表的总行数存在了磁盘上,所以执行 count(*) 会直接返回这个数,如果有 where ...
- ubuntu 14.04 安装openjdk 8
最近准备在ubuntu14.04上安装Oracle,但是需要提前安装jdk,发现问题挺多的,后面看到了如下的操作步骤,成功安装,特意记录下来. 致谢:https://www.yangshenglian ...
- 状态管理工具对比vuex、redux、flux
1.为什么要使用状态管路工具 在跨层级的组件之间传递信息,尤其是复杂的组件会非常困难.也不利于开发和维护,这时我们就a需要用到状态管理工具. 2.Flux
- 微信小程序支付功能讲解
前言:虽然小程序做过很多,但是一直觉得微信支付功能很是神秘,现在终于有机会接触心里还是有点小激动的,经过一番折腾发现支付也不过如此,在此记录下支付功能的实现过程 小程序的官方文档介绍到发起微信支付即调 ...
- idea 打包model 为jar包
1,在项目上鼠标右键 --> Open Module Settings 2, Artifacts --> + --> JAR --> From modules with dep ...
- 记一下今天上下班学的Thread
1 Thread 默认为前台线程,即主程序退出后,线程还可以继续(曾经就掉入这个坑中,使用两线程分别进行UDP收发,结果发线程结束了退出方法,收线程还在继续) 2 Thread 没有可以暂停,可以重新 ...
- 大数据学习第二章、HDFS相关概念
1.HDFS核心概念: 块 (1)为了分摊磁盘读写开销也就是大量数据间分摊磁盘寻址开销 (2)HDFS块比普通的文件块大很多,HDFS默认块大小为64MB,普通的只有几千kb 原因:1.支持面向大规模 ...
- 如何实现echarts组织结构图节点的收缩
echarts本身没有组织结构图的节点收缩功能,因为项目需求要用到此功能. 引入的echarts必须是2版本的,因为3.0取消了对组织结构图的支持.下载2版本的源码,找到关于onclick事件那部分的 ...