欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF1675B.Make It Increasing
Make It Increasing
Given integers . You can perform the following operation on them:
- select any element () and divide it by (round down). In other words, you can replace any selected element with the value (where is – round down the real number ).
Output the minimum number of operations that must be done for a sequence of integers to become strictly increasing (that is, for the condition to be satisfied). Or determine that it is impossible to obtain such a sequence. Note that elements cannot be swapped. The only possible operation is described above.
For example, let and a sequence of numbers be given. Then it is enough to perform two operations on it:
- Write the number instead of the number and get the sequence ;
- Then replace with and get the sequence .
The resulting sequence is strictly increasing because .
Input
The first line of the input contains an integer () — the number of test cases in the input.
The descriptions of the test cases follow.
The first line of each test case contains a single integer ().
The second line of each test case contains exactly integers ().
Output
For each test case, print a single number on a separate line — the minimum number of operations to perform on the sequence to make it strictly increasing. If a strictly increasing sequence cannot be obtained, print "-1".
Note
The first test case is analyzed in the statement.
In the second test case, it is impossible to obtain a strictly increasing sequence.
In the third test case, the sequence is already strictly increasing.
Samples
7
3
3 6 5
4
5 3 2 1
5
1 2 3 4 5
1
1000000000
4
2 8 7 5
5
8 26 5 21 10
2
5 14
2
-1
0
0
4
11
0
在线编程 IDE
建议全屏模式获得最佳体验
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |