欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF1625B.Elementary Particles
Elementary Particles
题目描述
火星人正在积极参与星际贸易。以其太空港闻名的奥林匹斯城,已经成为银河系各地货物的集散地。为了从遥远的星球运送更多的货物,火星人需要更快的飞船。
一组科学家正在进行实验,以制造新飞船的高速引擎。在当前的实验中,有 个基本粒子,第 个粒子的类型为 。
我们将粒子序列 的一个子区间定义为 ,其中左端点 和右端点 满足 。例如,序列 中, 且 时,子区间为 。如果两个子区间的端点至少有一个不同,则认为它们是不同的子区间。
注意,即使两个子区间作为序列完全相同,只要它们的端点不同,也被视为不同。例如,序列 的两个子区间:一个 ,另一个 ,它们都是 ,但由于端点不同,仍然被视为不同的子区间。
科学家们希望进行一次反应,得到两个长度相同但不同的子区间。记这个长度为 。这对子区间必须是“和谐的”,即存在某个 (),使得这两个子区间在第 个位置上的粒子类型相同。例如, 和 是和谐的,因为它们在第二个位置上都是 。而 和 则不是和谐的。
和谐子区间的长度越长,科学家们制造出高速引擎的机会就越大。因此,他们希望你计算由不同子区间组成的和谐对子区间的最大可能长度。
输入格式
第一行包含一个整数 (),表示测试用例的数量。接下来是每个测试用例的描述。
每个测试用例的第一行包含一个整数 (),表示粒子序列的长度。
第二行包含 个整数 (),表示每个粒子的类型。
保证所有测试用例的 之和不超过 。
输出格式
对于每个测试用例,输出一个整数,表示由不同子区间组成的和谐对子区间的最大可能长度。如果不存在这样的对子区间,输出 。
说明/提示
第一个测试用例如下图所示:

如图所示,你可以选择子区间 和 ,它们是一对和谐对子区间。它们的长度为 ,所以答案是 。
在第二个测试用例中,你需要选择两个子区间:一个 ,另一个 。可以发现这两个区间是一对和谐对子区间,并且由于端点不同,视为不同的子区间,尽管它们的内容完全相同。
在第三个测试用例中,无法构成和谐对子区间,因此答案为 。
由 ChatGPT 4.1 翻译
样例
4
7
3 1 5 2 1 3 4
6
1 1 1 1 1 1
6
1 4 2 8 5 7
2
15 15
4
5
-1
1
在线编程 IDE
建议全屏模式获得最佳体验
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |