题解 - Omkar and Password
题目 洛谷的 RMJ 挂了我就不挂洛谷了。
题目大意
给定长为 \(n\) 的数列,每次可以将相邻的且不相同的数字合并(即加和)。
问最短能合并成几个数。
思路简析
虽然只是道橙题,但挺有趣。
太菜了,开始被硬控 5mins 😇。
考虑如果整个数列都是相同的数的话,必然不能合并。
那么当数字不完全相同的时候,一个比较好的思路是:
考虑最大值的存在区间为 \(a_{[L, R]}\),将 \(a_{L-1}\) 或 a_{R+1}$ 与某个端点上的最大值合并,则得到严格最大值,再拿这个和别的合合合合合,就全吃了。
点击查看代码
没,