P14370 [JOISC 2018] 最差的记者 3 / Worst Reporter 3 Solution

P14370 [JOISC 2018] 最差的记者 3 / Worst Reporter 3Solution

注意:我个人推荐 LibreOJ 题面,看这份的样例图片会好不止亿点点。

前言

在考场上只拿了12 1212分(只想出了Subtask 2QwQ大佬勿喷!

这道题纯模拟可以把Subtask 2的分数拿下(因为数据实在太小了),时间复杂度O ( n + q t ) \mathcal{O}(n+qt)O(n+qt),已经到达10 14 10^{14}1014级别了,肯定爆。

所以我们需要一种算法可以达到O ( n + q ) \mathcal{O}(n+q)O(n+q)(即线性处理),好在它并不困难

思路

Part I.

我们会发现一件特别有意思的事情。

每个人的移动周期等于单次的移动距离。

其实这就好写了,我们也得到了一个我们需要的线性的方法:递推

把每个人的移动周期都用f i f_ifi记录下来(0 ≤ i ≤ n 0 \le i \le n0in)。

注意给旗手一个f 0 = 1 f_0 = 1f0=1,毕竟它前面没有人(题目已经说了)。

Part II.

第二件有意思的事情。

如果前面的人移动一次后超越了我,那么我就直接跟在他后面,即f i = f i − 1 f_i = f_{i-1}fi=fi1

小 L:如果我慢悠悠地移动咋办呢?

那么前面的人走⌈ d i f i − 1 ⌉ \lceil \frac{d_i}{f_{i-1}} \rceilfi1di次后我再跑,那么f i = f i − 1 × ⌈ d i f i − 1 ⌉ f_i = f_{i-1} \times \lceil \frac{d_i}{f_{i-1}} \rceilfi=fi1×fi1di

其实做到这里状态转移就已经推完了。


总结一下,这个状态转移其实就是

f ( x ) = { f i = f i − 1 ( d i ≤ f i − 1 ) f i = f i − 1 × ⌈ d i f i − 1 ⌉ ( d i ≥ f i − 1 ) f(x)=\left\{ \begin{aligned} f_i & = f_{i-1} & (d_i \le f_{i-1}) \\ f_i & = f_{i-1} \times \lceil \frac{d_i}{f_{i-1}} \rceil & (d_i \ge f_{i-1}) \\ \end{aligned} \right.f(x)=fifi=fi1=fi1×fi1di(difi1)(difi1)

Part III.

不过我们发现f i f_ifi0 ≤ i ≤ n 0 \le i \le n0in)会有很多是一样的,于是直接把他的左端点记录下来。

小 L:那么怎么处理这些呢?你是不是要一个时间复杂度低一点的算法?

我们发现它们都是倍增的(至少是2 22倍关系),所以可以直接把复杂度降到O ( log ⁡ V ) \mathcal{O}(\log V)O(logV)级别。

然后再和{ l , r } \{l, r\}{l,r}取交集就可以了。

贴两段比较没用的代码。

if(d[i]<=dp[i-1]){dp[i]=dp[i-1];le[i]=le[i-1];}else{dp[i]=((d[i]-1)/dp[i-1]+1)*dp[i-1];le[i]=i;}// 不懂的看上面去 :)
while(pos>=0){intx=t/dp[pos]*dp[pos];ans+=max(0ll,min(r,-1ll*le[pos]+x)-max(l,-1ll*pos+x)+1);pos=le[pos]-1;}

QwQ,绿题拿下!

后记

请勿抄袭题解,违者可能被洛谷棕名哦。

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

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

相关文章

继电器控制电路设计:从零实现方案

从零搭建一个可靠的继电器控制电路&#xff1a;不只是“接上线就能用” 你有没有遇到过这样的情况&#xff1f; 写好了代码&#xff0c;MCU GPIO也配置正确了&#xff0c;可一通电——继电器不动作、单片机复位、甚至烧了个IO口……明明只是想控制个灯泡或插座&#xff0c;怎么…

Windows平台常见USB转串口芯片驱动对比分析

USB转串口芯片驱动选型实战&#xff1a;从工程痛点看Windows平台四大方案的生死博弈你有没有遇到过这样的场景&#xff1f;项目现场一切就绪&#xff0c;设备通电、线缆插好&#xff0c;结果上位机死活读不到串口数据。重启无效&#xff0c;换电脑还是不行——最后发现是USB转串…

Vitis平台FPGA加速项目实战案例详解

FPGA加速实战&#xff1a;用Vitis把图像处理性能拉满的全过程最近在做一个边缘计算项目&#xff0c;客户要求对1080p视频流做实时预处理——既要跑Sobel边缘检测&#xff0c;又要加FIR滤波&#xff0c;还得控制功耗。一开始我们用树莓派OpenCV硬扛&#xff0c;结果帧率卡在15fp…

Day 12:【99天精通Python】文件操作 - 让数据持久化保存

Day 12&#xff1a;【99天精通Python】文件操作 - 让数据持久化保存 前言 欢迎来到第12天&#xff01; 在前面的11天里&#xff0c;我们写的所有程序&#xff0c;数据都保存在内存中。一旦程序运行结束或者电脑关机&#xff0c;那些辛苦计算出来的结果、用户输入的信息瞬间就消…

电路仿真circuits网页版在模拟信号调理中的实践解析

用网页电路仿真玩转模拟信号调理&#xff1a;从零搭建心电前置放大器你有没有过这样的经历&#xff1f;手头有个传感器项目&#xff0c;信号微弱得像耳语&#xff0c;噪声却吵得像工地施工。想做个放大滤波电路&#xff0c;可一上电就失真、振荡、输出贴电源轨……改一次PCB要等…

Altium Designer铺铜与过孔连接方式详解

Altium Designer铺铜与过孔连接实战指南&#xff1a;从原理到一次成功的PCB设计你有没有遇到过这样的情况&#xff1f;明明所有走线都连上了&#xff0c;DRC检查却报出一堆“Unconnected Pin”&#xff1b;回流焊后发现几个接地过孔虚焊&#xff1b;高速信号完整性测试时噪声异…

RISC-V中断上下文保存与恢复流程系统学习

深入RISC-V中断机制&#xff1a;从硬件触发到上下文恢复的完整路径你有没有遇到过这样的问题——系统突然“卡死”&#xff0c;调试器显示程序跳到了一个完全意想不到的地方&#xff1f;或者在写中断服务例程时&#xff0c;发现某个变量莫名其妙地被改写了&#xff1f;如果你正…

PCB布局前的电路行为预判:电路仿真详解

PCB布局前的电路行为预判&#xff1a;为什么高手都在用仿真“排雷”&#xff1f;你有没有经历过这样的场景&#xff1f;PCB板子刚焊好&#xff0c;上电测试却发现电源振荡、信号失真、噪声超标……改版&#xff1f;又要等一周&#xff01;成本又涨几千&#xff01;更糟的是&…

新手必看:TPS5430 buck电路入门教程

从零开始搞懂TPS5430 Buck电路&#xff1a;新手也能轻松上手的实战指南 你是不是也曾在设计电源时&#xff0c;面对一堆参数和拓扑图一头雾水&#xff1f; 想给STM32、FPGA或者传感器供电&#xff0c;却不知道该用LDO还是DC-DC&#xff1f; 看到“buck电路图”、“环路补偿”…

HBuilderX Windows环境配置:新手教程(零基础必看)

从零开始玩转 HBuilderX&#xff1a;Windows 下的前端开发第一站你是不是也曾在搜索“前端怎么入门”时&#xff0c;被一堆专业术语搞得晕头转向&#xff1f;Webpack、Babel、TypeScript、Node.js……光是名字就让人想放弃。其实&#xff0c;前端开发的第一步&#xff0c;完全可…

MOSFET工作原理项目应用:DC-DC变换器驱动设计示例

从米勒效应到高效驱动&#xff1a;MOSFET在同步Buck变换器中的实战设计揭秘你有没有遇到过这样的情况&#xff1f;明明选了低导通电阻的MOSFET&#xff0c;效率却上不去&#xff1b;开关频率提不上去&#xff0c;温升还特别高&#xff1b;更离谱的是&#xff0c;示波器一测&…

持续提升专业技能和行业认知,利用碎片时间学习新工具或方法论

职场思维一&#xff1a;结果导向关注产出而非过程&#xff0c;以目标为驱动完成工作。将大目标拆解为可量化的小任务&#xff0c;定期复盘进度。例如设定季度业绩指标&#xff0c;每周检查完成度并及时调整策略。职场思维二&#xff1a;主动学习持续提升专业技能和行业认知&…

阐述多 Agent 系统中的组织模型设计:角色分配、权限管理与任务协同策略

阐述多 Agent 系统中的组织模型设计&#xff1a;角色分配、权限管理与任务协同策略 一、引言&#xff1a;为什么多 Agent 系统需要“组织模型” 随着人工智能系统从“单智能体”向“群体智能”演进&#xff0c;多 Agent 系统&#xff08;Multi-Agent System, MAS&#xff09;逐…

Xilinx Ultrascale+平台下XDMA配置全面讲解

Xilinx Ultrascale平台下XDMA实战配置全解析&#xff1a;从IP定制到Linux零拷贝传输 为什么高速数据通路离不开XDMA&#xff1f; 在如今的AI推理加速、雷达信号处理和医学成像系统中&#xff0c;FPGA作为协处理器的角色愈发关键。但一个常被忽视的问题是&#xff1a; 再强大…

基于改进多目标灰狼优化算法的考虑V2G技术的风、光、荷、储微网多目标日前优化调度研究(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

【无功优化】“碳中和”目标下电气互联系统有功-无功协同优化模型(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

Multisim仿真电路图实例详解H桥驱动电路正反转原理验证

用Multisim“手把手”验证H桥驱动&#xff1a;从零搞懂直流电机正反转原理你有没有遇到过这种情况——明明代码写对了&#xff0c;接线也没错&#xff0c;可电机一通电就“炸管”&#xff1f;或者方向调反了&#xff0c;想改又不敢动硬件&#xff0c;生怕再烧一颗MOSFET&#x…

强烈安利!9大AI论文网站测评,本科生毕业论文必备

强烈安利&#xff01;9大AI论文网站测评&#xff0c;本科生毕业论文必备 2026年AI论文工具测评&#xff1a;为何需要这份榜单&#xff1f; 在当前学术研究日益依赖AI辅助工具的背景下&#xff0c;本科生在撰写毕业论文时常常面临资料查找困难、写作效率低、格式不规范等问题。为…

MusicFree:开源多平台聚合音乐软件

数字音乐版权的分散化使得听众经常需要在多个应用程序之间切换。为了解决这种碎片化的体验&#xff0c;开源社区推出了 MusicFree。这款软件在本质上是一个集成播放协议的空壳&#xff0c;本身不带有任何曲库内容。它通过插件化的设计&#xff0c;将软件的功能性与内容源彻底剥…

【顶级SCI复现】高比例可再生能源并网如何平衡灵活性与储能成本?虚拟电厂多时间尺度调度及衰减建模(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…