欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF1735B.Tea with Tangerines
Tea with Tangerines
题目描述
有 块橘子皮,第 块的大小为 。每一步可以将一块大小为 的橘子皮分成两块正整数大小的橘子皮 和 ,满足 。
你希望对于任意两块橘子皮,它们的大小之比严格小于 。换句话说,不存在两块大小分别为 和 的橘子皮,使得 。请问最少需要多少步才能满足上述条件?
输入格式
输入的第一行包含一个整数 (),表示测试用例的数量。接下来是每个测试用例的描述。
每个测试用例的第一行包含一个整数 ()。
接下来一行包含 个整数 ()。
输出格式
对于每个测试用例,输出一行,表示最少需要的步数。
说明/提示
在第一个测试用例中,初始有一块大小为 的橘子皮,因此所有最终的橘子皮都必须为 。总共需要的步数为:。
在第二个测试用例中,只有一块橘子皮,无需操作,答案为 步。
在第三个测试用例中,一种可能的切法为:$600,\ 900,\ (600 | 700),\ (1000 | 1000),\ (1000 | 1000 | 550)$。你可以在下图中看到这种切法。最大的一块为 ,且小于最小一块 的 倍。共进行了 步。可以证明这是最少的步数。

由 ChatGPT 4.1 翻译
样例
3
5
1 2 3 4 5
1
1033
5
600 900 1300 2000 2550
10
0
4
在线编程 IDE
建议全屏模式获得最佳体验
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |