欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF1760E.Binary Inversions
Binary Inversions
题目描述
给定一个长度为 的二进制数组 。你最多可以对其进行一次操作。在一次操作中,你可以选择任意一个元素并将其翻转:将 变为 ,或将 变为 。
在最多进行一次操作后,该数组最多可以有多少个逆序对 ?
二进制数组是指只包含 和 的数组。
数组中的逆序对数量是指满足 且 的下标对 的个数。
输入格式
输入包含多组测试用例。第一行包含一个整数 ()——表示测试用例的数量。接下来的每组测试用例描述如下。
每组测试用例的第一行包含一个整数 ()——数组的长度。
接下来一行包含 个用空格分隔的正整数 ()——数组的元素。
保证所有测试用例中 的总和不超过 。
输出格式
对于每个测试用例,输出一个整数,表示在最多进行一次操作后,数组可以拥有的最大逆序对数量。
说明/提示
对于第一个测试用例,初始时逆序对由下标对 、、 组成,共 个,这已经是最大值。
对于第二个测试用例,初始时逆序对由下标对 、、、 组成,共 个。但如果将第一个元素翻转,数组变为 ,此时逆序对由下标对 、、、、、、 组成,共 个,这是可能的最大值。
由 ChatGPT 4.1 翻译
样例
5
4
1 0 1 0
6
0 1 0 0 1 0
2
0 0
8
1 0 1 1 0 0 0 1
3
1 1 1
3
7
1
13
2
在线编程 IDE
建议全屏模式获得最佳体验
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |