欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF2128A.Recycling Center
Recycling Center
题目描述
在回收中心,有 个垃圾袋,第 个垃圾袋的重量为 。每一秒钟,会依次发生以下两个操作:
- 首先,你必须选择一个垃圾袋并销毁它。如果该垃圾袋的重量严格大于 ,则需要花费 个硬币,否则不需要花费硬币。
- 然后,剩余每个垃圾袋的重量都会变为原来的两倍。
你需要花费的最少硬币数是多少,才能销毁所有垃圾袋?
输入格式
每个测试点包含多组测试数据。第一行包含测试用例数 ()。接下来是每组测试数据的描述。
每组测试数据的第一行包含两个整数 和 (,)。
每组测试数据的第二行包含 个整数 (),表示每个垃圾袋的重量。
输出格式
对于每组测试数据,输出一个整数,表示销毁所有垃圾袋所需的最少硬币数。
说明/提示
在下面的解释中:
- 蓝色数字表示被免费销毁的垃圾袋,
- 红色数字表示被花费 个硬币销毁的垃圾袋,
- 黑色数字表示尚未被销毁的垃圾袋。
对于第一个测试用例,一种方案如下:
- , 被免费销毁,因为 。
- , 被免费销毁,因为 。
- $[\color{blue}{10}, \color{blue}{8}, 120, 8, \color{red}{32}]$, 被花费 个硬币销毁,因为 。
- $[\color{blue}{10}, \color{blue}{8}, 240, \color{blue}{8}, \color{red}{32}]$, 被免费销毁,因为 。
- $[\color{blue}{10}, \color{blue}{8}, \color{red}{240}, \color{blue}{8}, \color{red}{32}]$, 被花费 个硬币销毁,因为 。
总共花费了 个硬币,并且可以证明这是最优的。
对于第二个测试用例,一种方案如下:
- $[1\,000\,000\,000, 1\,000\,000\,000, 1\,000\,000\,000]$
- $[\color{red}{1\,000\,000\,000}, 2\,000\,000\,000, 2\,000\,000\,000]$, 被花费 个硬币销毁,因为 。
- $[\color{red}{1\,000\,000\,000}, \color{red}{2\,000\,000\,000}, 4\,000\,000\,000]$, 被花费 个硬币销毁,因为 。
- $[\color{red}{1\,000\,000\,000}, \color{red}{2\,000\,000\,000}, \color{red}{4\,000\,000\,000}]$, 被花费 个硬币销毁,因为 。
由 ChatGPT 4.1 翻译
样例
4
5 10
10 4 15 1 8
3 42
1000000000 1000000000 1000000000
10 30
29 25 2 12 15 42 14 6 16 9
10 1000000
1 1 1 1 1 1 1 1 1 864026633
2
3
6
1
在线编程 IDE
建议全屏模式获得最佳体验
键盘快捷键
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |
第 1 行,第 1 列
0 字符
-
最近自测结果
暂未运行
最近递交结果
暂无递交记录