ARC073F Many Moves

当你填表法推了半年没推出来,为什么不试试刷表法呢?

洛谷传送门

在一行中有 n个格子,从左往右编号为 1n

2 颗棋子,一开始分别位于位置AB。按顺序给出Q个要求,每个要求是如下形式:

  • 给出一个位置 xi,要求将两个棋子中任意一个移动到位置 xi

将一颗棋子移动一格需要花费 1 秒,就是说将棋子从 X 位置移动到 Y 位置需要花费 |XY| 秒。

为了回答要求,你只能移动棋子,并且同一时刻只能移动一颗棋子。要求的顺序是不可更改的。在同一时间允许两颗棋子在同一个格子内。

n,q2e5


刷表法的转移方程:

fi,j+|xixi+1|fi+1,j

min{fi,j+|jxi+1|}fi+1,xi

开三个线段树,维护 fi,j,fi,jj,fi,j+j 即可。

posted @   FLY_lai  阅读(8)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!
点击右上角即可分享
微信分享提示