P5537 题解
blog。今天在 XDFZ 听 ljy 讲的串串(?)题,瞎写写就混了个最优解,来发个题解(
注意到树的形态不变,所以可以记录兄弟间的编号 rank。每个点就可以表示为若干 rank 构成的路径,例如下图:
然后将每个点的这个路径压成 hash,记为
假设从
发现这是可二分的,即:如果存在
所以直接二分出最小的
这个问题只需要做到维护
注意到我们可以线段树上二分,这样就做到了
代码是最优解的一发,会有一点点抽象,不过应该看得懂 /cy。
贺了 OIWiki 的 hash 表,也可以用 unordered_map
实现,不过前者会快 4s。
code,时间复杂度
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!