计蒜客-2137-守望者的距离(dp)

A的跑步速度为 17m/s,以这样的速度是无法逃离荒岛的。庆幸的是A拥有闪烁法术,可在 1s 内移动 60m,不过每次使用闪烁法术都会消耗魔法值 1010 点。A的魔法值恢复的速度为 44 点 /s/s,只有处在原地休息状态时才能恢复。

现在已知A的魔法初值 MM,他所在的初始位置与岛的出口之间的距离 SS,岛沉没的时间 TT。你的任务是写一个程序帮助A计算如何在最短的时间内逃离荒岛,若不能逃出,则输出A在剩下的时间内能走的最远距离。注意:A跑步、闪烁或休息活动均以秒( ss )为单位,且每次活动的持续时间为整数秒。距离的单位为米( mm )。

输入格式
包括空格隔开的三个非负整数 M,S,TM,S,T。

输出格式
第 11 行为字符串"Yes"或"No"(区分大小写),即A是否能逃离荒岛。

第 22 行包含一个整数。第一行为"Yes"(区分大小写)时表示A逃离荒岛的最短时间;第一行为"No"(区分大小写)时表示A能走的最远距离。

数据范围
30%30% 的数据满足:1 \le T \le 10, 1 \le S \le 1001≤T≤10,1≤S≤100;

50%50% 的数据满足:1 \le T \le 1000, 1 \le S \le 100001≤T≤1000,1≤S≤10000;

100%100% 的数据满足:1 \le T \le 300000, 0 \le M \le 1000, 1 \le S \le 10^81≤T≤300000,0≤M≤1000,1≤S≤10
8

输出时每行末尾的多余空格,不影响答案正确性

样例输入1复制
39 200 4
样例输出1复制
No
197
样例输入2复制
36 255 10
样例输出2复制
Yes
6

本题可以利用dp数组来选取最优状态

#include<iostream>
using namespace std;

const int max_n=3e5+500;
int m,s,t;
int dp1[max_n],dp2[max_n];

/*
相当于分成两个人来赛跑,每一秒之内都利用最佳策略,也就是跑的最多
的方法来跑步。 
*/
int main(){
	cin >> m>> s>> t;
	dp1[0]=dp2[0]=0;//dp2表示只利用闪现来移动的距离 
	int i=1;
	for(i=1;i<=t;i++){
		//回蓝和闪现是矛盾的,而这只能取其一 
		if(m>=10){
			//蓝够了,就闪现
			dp2[i]=dp2[i-1]+60;
			m-=10; 
		}else{
			//蓝不够 
			m+=4;
			dp2[i]=dp2[i-1];
		}
		//选取同一时间能到达的最远距离 ,同时闪现和正常也是矛盾的
		//智能取其一 
		dp1[i]=max(dp1[i-1]+17,dp2[i]);
		if(dp1[i]>=s) break;
	}
	if(i<=t){
		cout<<"Yes"<<endl;
		cout<<i<<endl;
	}else{
		cout<<"No"<<endl;
		cout<<dp1[t]<<endl;
	}
	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
对于守望者的逃离这道题目,可以使用动态规划或贪心算法来解决。首先我们需要理解题目的要求,甲在光明大道的起始点,每秒有三种选择:1.行使17m,2.在蓝量足够的情况下行使60m,蓝量减去10,3.行使0m,恢复4蓝量。我们需要判断甲能否在初始蓝量为m的情况下在t秒内到达终点。 为了解决这个问题,我们可以使用一个循环来模拟每一分钟的情况。假设甲在当前的时间点有一定的蓝量,我们可以算出他在下一分钟时的蓝量,并根据这个蓝量来判断他的行动选择。如果蓝量足够,我们选择行使60m并减去10的蓝量;如果蓝量不足,我们选择行使17m;如果蓝量为0,我们选择恢复4蓝量。 在每一分钟的算中,我们需要对甲的位置进行更新,并记录下他到达终点的最短时间。当循环结束后,我们可以得到甲是否能在规定时间内到达终点,如果能,输出"Yes"并换行输出所需时间;如果不能,输出"No"并换行输出甲最长能达到的距离。 这样,我们就可以使用C语言编写代码来解决守望者的逃离这道题目了。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [[NOIP2007 普及组] 守望者的逃离](https://blog.csdn.net/TGxyt_blog/article/details/122783995)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小吴同学GOGOGO

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值