恶魔猎手尤迪安野心勃勃,他背叛了暗夜精灵,率领深藏在海底的娜迦族企图叛变。
守望者在与尤迪安的交锋中遭遇了围杀,被困在一个荒芜的大岛上。
为了杀死守望者,尤迪安开始对这个荒岛施咒,这座岛很快就会沉下去。到那时,岛上的所有人都会遇难。
守望者的跑步速度为 17m/s,以这样的速度是无法逃离荒岛的。庆幸的是守望者拥有闪烁法术,可在 1s 内移动 60m,不过每次使用闪烁法术都会消耗魔法值 10 点。守望者的魔法值恢复的速度为 4 点每秒,只有处在原地休息状态时才能恢复。
现在已知守望者的魔法初值 M,他所在的初始位置与岛的出口之间的距离 S,岛沉没的时间 T。你的任务是写一个程序帮助守望者计算如何在最短的时间内逃离荒岛,若不能逃出,则输出守望者在剩下的时间内能走的最远距离。
注意:守望者跑步、闪烁或休息活动均以秒为单位,且每次活动的持续时间为整数秒。距离的单位为米。
输入数据共一行三个非负整数,分别表示 M,S,T。
输出数据共两行。
第一行一个字符串 Yes 或 No,即守望者是否能逃离荒岛。
第二行包含一个整数。第一行为 Yes 时表示守望者逃离荒岛的最短时间;第一行为 No 时表示守望者能走的最远距离。
输入 #1
39 200 4
输出 #1
No 197
输入 #2
36 255 10
输出 #2
Yes 6
对于 30% 的数据,1≤T≤10,1≤S≤100;
对于 50% 的数据,1≤T≤10^3,1≤S≤10^4;
对于 100% 的数据,1≤T≤3×10^5,0≤M≤10^3,1≤S≤10^8。
- #include
- using namespace std;
- #define MAXN 300010
- int main()
- {
- int m,s,t,i,f[MAXN];
- cin>>m>>s>>t;
- f[0]=0;
- for(i=1;i<=t;i++)
- {
- if(m>=10)
- {
- f[i]=f[i-1]+60;
- m-=10;
- }
- else
- {
- f[i]=f[i-1];
- m+=4;
- }
- }
- for(i=1;i<=t;i++)
- {
- if(f[i]
-1]+17) f[i]=f[i-1]+17; - if(f[i]>=s)
- {
- cout<<"Yes"<
- return 0;
- }
- }
- cout<<"No"<
- return 0;
- }
题解
主算法:动态规划、贪心
题意分析:
在最短时间走最多路程,移动中每秒有3种选择:
- 休息(魔法+4);
- 跑步(路程+17);
- 闪烁(魔法-10,路程+60)。
思路:
- 休息是为了闪烁;
- 能闪烁就闪烁;
- 在没法闪烁时,要判断是休息还是跑步。
可以把跑步和闪烁分开处理:
闪烁:当m>=10时,f[i]=f[i-1]+60
当m<10时,f[i]=f[i-1] (m=m+4)
跑步:f[i]=f[i-1]+17
最后合并得到状态转移方程:![f[i]=max(f[i],f[i-1]+17)](https://latex.codecogs.com/gif.latex?f%5Bi%5D%3Dmax%28f%5Bi%5D%2Cf%5Bi-1%5D+17%29)
预处理:
- #include
- using namespace std;
- #define MAXN 300010//定义常量
定义变量:
int m,s,t,i,f[MAXN];
输入:
cin>>m>>s>>t;
动态规划处理:
- for(i=1;i<=t;i++)
- {
- if(m>=10)
- {
- f[i]=f[i-1]+60;
- m-=10;
- }
- else
- {
- f[i]=f[i-1];
- m+=4;
- }//引入方程
- }
判断输出:
- for(i=1;i<=t;i++)
- {
- if(f[i]
-1]+17) f[i]=f[i-1]+17; - if(f[i]>=s)
- {
-
-
相关阅读:
栈的实现-c语言实现
用正向迭代器封装实现反向迭代器
嵌入式快速入门学习笔记-input输入子系统
六、表空间管理
网络编程之epoll源码深度剖析
Redis查找并删除key
BUUCTF中的web
不到3000块钱,如何支撑起每月500万次访问量及80TB流量的网站?
【设计模式】六、建造者模式
【OBS】P B 丢帧阈值 buffer_duration_usec
-
原文地址:https://blog.csdn.net/algorithmyyds/article/details/126159883