[NOIP2007 普及组] 守望者的逃离 题解

news2024/9/20 22:32:04

题意

给定 M ( 0 ≤ M ≤ 1 0 3 ) , S ( 1 ≤ S ≤ 1 0 8 ) , T ( 1 ≤ T ≤ 3 × 1 0 5 ) M(0 \leq M \leq 10^3),S(1 \leq S \leq 10^8),T(1 \leq T \leq 3\times 10^5) M(0M103),S(1S108),T(1T3×105),守望者开始在位置 0 0 0,对于每一秒(以下每一种操作的持续时间都是一整秒),有以下三种操作,可以选择其中一种:

  • 当前位置增加 17 17 17,不改变 M M M
  • M ≥ 10 M \geq 10 M10 时,可将当前位置增加 60 60 60,并将 M M M 扣除 10 10 10
  • 不移动位置,并将 M ← M + 4 M \gets M + 4 MM+4

求守望者能否在 T T T 秒内走 S S S 个位置,如果可以,输出 Yes 和最短在第几秒后可以走超过 S S S 个位置;否则输出 No,并输出在第 T T T 秒最远可以走到哪里。

思路

考虑当 M = 0 M = 0 M=0 时,如果剩余路程还很长,则可注意到对于每一次普通的走路在 7 s 7s 7s 内可以走 119 m 119m 119m,用特殊操作(进行五次操作 3 3 3 和两次操作 2 2 2 可以将路程增加 120 m 120m 120m ),因此特殊操作的速度显然快于普通操作。

首先令 d p i dp_i dpi 表示在第 i i i 秒内最远可以走到哪:

  • M ≥ 10 M \geq 10 M10 时, d p i ← d p i − 1 + 60 , M ← M − 10 dp_i \gets dp_{i - 1} + 60,M \gets M - 10 dpidpi1+60,MM10
  • 否则, d p i ← d p i − 1 M ← M + 4 dp_i \gets dp_{i - 1}M \gets M + 4 dpidpi1MM+4

此时求出的还不是第 i i i 秒的最佳情况,毕竟你进行操作 2 2 2 增加魔法值的同时通过进行操作 1 1 1 肯定在第 i i i 秒时更优,因此再次循环:

  • 如果 d p i < d p i − 1 + 17 , d p i ← d p i − 1 + 17 dp_i < dp_{i - 1} + 17,dp_i \gets dp_{i - 1} + 17 dpi<dpi1+17,dpidpi1+17

从而达到真正能求出 d p i dp_i dpi 而不影响进行操作 2 , 3 2,3 2,3 的效果。

最后进行相应判断即可。
在这里插入图片描述

代码

#include<bits/stdc++.h>
#define int long long
using namespace std;
int m,s,t,dp[300005];
signed main() {
	scanf("%lld %lld %lld",&m,&s,&t);
	for(int i = 1;i <= t;i++) {
		if(m >= 10) m -= 10,dp[i] = dp[i - 1] + 60;
		else m += 4,dp[i] = dp[i - 1];
	}
	for(int i = 1;i <= t;i++) {
		if(dp[i] < dp[i - 1] + 17) dp[i] = dp[i - 1] + 17;
		if(dp[i] >= s) {
			printf("Yes\n%lld",i);
			return 0;
		}
	}
	printf("No\n%lld",dp[t]);
    return 0;
}


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

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

相关文章

C++调用C#方法(附踩坑点)

C调用C#方法 写在前面效果思路步骤可能的问题 写在后面 写在前面 工作需要用C调用C#写到代码&#xff0c;看来网上写的方法&#xff0c;自己也踩了一些坑&#xff0c;这里总结一下&#xff0c;我只试了CLR的方法。 主要参考了下面几篇博客 C调用C#库简单例程&#xff08;Lucky…

【BUU】[NewStarCTF 2023 公开赛道]Final -CP读取文件内容

漏洞检测 访问首页发现是ThinkPHP5 的站点 用工具扫描一下,发现存在ThinkPHP5.0.23 RCE漏洞 访问验证,写入shell 成功写入shell. 根目录发现flag,但是权限不足 提权获取flag 准备提权,这里一开始尝试了find,但是find权限不足 尝试采用cp命令,移动到web目录,发现访问还是…

MySQL InnoDB中一个update语句从执行到提交的全过程(3)

接上文MySQL InnoDB中一个update语句从执行到提交的全过程&#xff08;2&#xff09;-CSDN博客 目录 六、本地提交 怎样保证binlog和redo log的状态一致呢&#xff1f; MySQL 中的内部 XA 机制 宕机时不同状态的处理 物理落盘策略 七、主备复制 八、返回提交成功 总结一…

Windows 10/11和Linux双系统用户请勿安装最新更新 否则将无法启动

据蓝点网报道&#xff0c;Windows 10/11 最新累积更新存在已知问题&#xff0c;如果你同时安装了 Linux 双系统则会在更新后导致系统无法正常启动。 启动时会出现如下报错&#xff1a; Verifiying shim SBAT data failed: Security Policy Violation.Something has gone serio…

私域场景中的数字化营销秘诀

​在当今的商业世界&#xff0c;私域场景的营销变得愈发重要。今天咱们就来深入探讨一下私域场景中的几个关键营销手段。 一、会员管理与营销 企业一旦拥有完善的会员体系&#xff0c;数字化手段就能大放异彩。它可以助力企业对会员进行精细划分&#xff0c;深度了解会员的消费…

win11笔记本电脑 声音输出设置为扬声器 | 添加蓝牙设备 | win11环境变量设置

&#x1f947; 版权: 本文由【墨理学AI】原创首发、各位读者大大、敬请查阅、感谢三连 &#x1f389; 声明: 作为全网 AI 领域 干货最多的博主之一&#xff0c;❤️ 不负光阴不负卿 ❤️ 文章目录 win11笔记本电脑 声音输出设置为扬声器搜索设置&#xff0c;打开设置选择声音选…

AI安全-文生图

1 需求 2 接口 3 示例 大模型图像安全风险探析 - 先知社区 前言 文生图模型是一种新兴的人工智能技术,它通过对大规模文本数据的学习,能够生成逼真的图像。这种模型包含两个主要组件:一个文本编码器和一个图像生成器。 文本编码器接收文本输入,并将其转换为一种数字化的表示…

Idea开发代码注释规范

规范 类注释&#xff1a;每个类都应该有一个简短的注释&#xff0c;描述这个类的用途和主要功能。注释应该放在类的声明之前&#xff0c;使用JavaDoc格式。 /*** 这是一个示例类&#xff0c;用于演示如何编写类注释。*/ public class ExampleClass {// ... }方法注释&#xf…

【Oracle点滴积累】解决PrereqSession failed: RawInventory gets null OracleHomeInfo故障的方法

广告位招租&#xff01; 知识无价&#xff0c;人有情&#xff0c;无偿分享知识&#xff0c;希望本条信息对你有用&#xff01; 今天和大家分享在安装Oracle Critical Patch Update (Patch Number:33806138) 遇到PrereqSession failed: RawInventory gets null OracleHomeInfo故…

github官网在线通过vscode编辑器模式查看编辑代码

文章目录 背景步骤关于快捷键话外 背景 今天新发现的一个小玩意儿 步骤 在github项目主页&#xff08;我尝试了无痕模式不行&#xff09; 按键盘的.这个按键&#xff0c;就是m右边2个&#xff0c;然后就会打开这个网站 github.dev/xxx 首次进入的时候&#xff0c;会像首次…

IDEA系列(四):IDEA导入Maven工程项目并配置Tomcat启动

IDEA系列(四)&#xff1a;IDEA导入Maven工程项目并配置Tomcat启动 前言 【本篇使用IDEA版本&#xff1a;大概2020版本&#xff0c;较早了&#xff0c;不过版本大体一致】【若需要码&#xff0c;请扫描关注编程D艺术&#xff0c;回复idea2024&#xff0c;获取码使你的IDEA更加方…

Arm-v8/v9虚拟化原理---aarch64_virtualization_guide

一、相关参考&#xff08;请仅参考&#xff0c;任意一篇足矣&#xff09; 1.https://www.cnblogs.com/LoyenWang/p/13584020.html 2.https://zhuanlan.zhihu.com/p/470045640 3.万字剖析 Armv8 架构虚拟化-腾讯云开发者社区-腾讯云 4.https://zhuanlan.zhihu.com/p/5290842…

Docker——常用命令

1.Docker是做什么的&#xff1f; Docker 是一个开源的应用容器引擎&#xff0c;它让开发者可以打包他们的应用以及依赖包到一个可移植的容器中&#xff0c;然后发布到任何流行的 Linux 机器上&#xff0c;也可以实现虚拟化。它可以帮助我们下载应用镜像&#xff0c;创建并运行镜…

SSM宠物领养系统-计算机毕设定制-附项目源码(可白嫖)55139

目 录 摘要 1 绪论 1.1 意义 1.2国内外研究现状 1.3ssm框架 1.4Vue.js 主要功能 1.4论文结构与章节安排 2 2 宠物领养系统系统分析 2.1 可行性分析 2.2 系统流程分析 2.2.1 数据增加流程 2.2.2 数据修改流程 2.2.3数据删除流程 2.3 系统功能分析 2.3.1功能性分析…

泰坦尼克号 - 从灾难中学习机器学习/Titanic - Machine Learning from Disaster(kaggle竞赛)第一集(了解赛题)

此次目的&#xff1a; 准备出几期博客来记录我学习kaggle数据科学入门竞赛的过程&#xff0c;顺便也将其中所学习到的知识分享出来。这是第一集&#xff08;了解赛题&#xff09;&#xff0c;后面还会更新更详尽的代码和讲解等。&#xff08;所学主要的内容来自与b站大学恩师“…

从数据分析到智能生产:AI在工业中的应用与未来

导语 | 人工智能技术的迅猛发展&#xff0c;正在引领第四次工业革命悄然而至。尽管 AI 技术在工业领域的部署仍有诸多难题亟待解决&#xff0c;但这并不能阻挡历史趋势的车轮滚滚向前&#xff0c;AI 正在为工业领域带来新的变革。今天&#xff0c;我们特邀了上海腾展长融董事 &…

MybatisPlus使用指南

MybatisPlus 1. 快速入门1.1 入门案例1.2 常见注解1.3 常见配置 2. 核心功能2.1 条件构造器2.2 自定义SQL2.3 Service接口 3. 扩展功能3.1 代码生成3.2 静态工具3.3 逻辑删除 4. 插件功能4.1 分页插件4.2 通用分页实体 1. 快速入门 1.1 入门案例 步骤一&#xff1a;引入Mybat…

初阶数据结构排序之插入排序

排序01 插⼊排序 基本思想 直接插⼊排序是⼀种简单的插⼊排序法&#xff0c;其基本思想是&#xff1a;把待排序的记录按其关键码值的⼤⼩逐个插 ⼊到⼀个已经排好序的有序序列中&#xff0c;直到所有的记录插⼊完为⽌&#xff0c;得到⼀个新的有序序列 。 实际中我们玩扑克牌…

uniapp 日常业务 随便写写 源码

现成的组件 直接用 <template><view style"margin: 10rpx;"><view class"tea-header"><text class"tea-title">礼尚往来</text><view class"tea-view-all"><text>查看全部</text>&l…

Redis 如何实现高并发

Redis 如何实现高并发 1、架构概述2、读写分离的优势3、注意事项 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; Redis&#xff0c;作为一个高性能的键值对存储系统&#xff0c;通过其独特的设计和优化策略&#xff0c;能够有效地支持高并发…