欢迎来到起遇信息学
起遇信息学正处于上线筹建阶段,以下功能已全部开放免费体验: ✅ 完整题库浏览与代码提交评测(C / C++ / Python / Java 等) ✅ 入门到进阶的系列课程试读、作业与考试 ✅ AI 提示、AI 作业分析等智能助教功能 ✅ 赛事模拟与个人能力报告 ✅ 邮箱注册开放 ⏳ 付费课程订阅与微信/支付宝支付通道 ⏳ 手机号登录,微信扫码登录、微信公众号绑定 使用中如遇任何问题,欢迎通过页面底部 **"联系我们"** 与我们沟通。
CF1354A.Alarm Clock
Alarm Clock
Polycarp has spent the entire day preparing problems for you. Now he has to sleep for at least minutes to feel refreshed.
Polycarp can only wake up by hearing the sound of his alarm. So he has just fallen asleep and his first alarm goes off in minutes.
Every time Polycarp wakes up, he decides if he wants to sleep for some more time or not. If he's slept for less than minutes in total, then he sets his alarm to go off in minutes after it is reset and spends minutes to fall asleep again. Otherwise, he gets out of his bed and proceeds with the day.
If the alarm goes off while Polycarp is falling asleep, then he resets his alarm to go off in another minutes and tries to fall asleep for minutes again.
You just want to find out when will Polycarp get out of his bed or report that it will never happen.
Please check out the notes for some explanations of the example.
Input
The first line contains one integer () — the number of testcases.
The only line of each testcase contains four integers () — the time Polycarp has to sleep for to feel refreshed, the time before the first alarm goes off, the time before every succeeding alarm goes off and the time Polycarp spends to fall asleep.
Output
For each test case print one integer. If Polycarp never gets out of his bed then print -1. Otherwise, print the time it takes for Polycarp to get out of his bed.
Note
In the first testcase Polycarp wakes up after minutes. He only rested for minutes out of minutes he needed. So after that he sets his alarm to go off in minutes and spends minutes falling asleep. Thus, he rests for more minutes, totaling in minutes of sleep. Then he repeats the procedure three more times and ends up with minutes of sleep. Finally, he gets out of his bed. He spent minutes before the first alarm and then reset his alarm four times. The answer is .
The second example is almost like the first one but Polycarp needs minutes of sleep instead of . However, that changes nothing because he gets minutes with these alarm parameters anyway.
In the third testcase Polycarp wakes up rested enough after the first alarm. Thus, the answer is .
In the fourth testcase Polycarp wakes up after minutes. Unfortunately, he keeps resetting his alarm infinitely being unable to rest for even a single minute :(
Samples
7
10 3 6 4
11 3 6 4
5 9 4 10
6 5 2 3
1 1 1 1
3947465 47342 338129 123123
234123843 13 361451236 361451000
27
27
9
-1
1
6471793
358578060125049
在线编程 IDE
建议全屏模式获得最佳体验
| 进入全屏编程 | Alt+E |
| 递交评测 | Ctrl+Enter |
| 注释/取消注释 | Ctrl+/ |
| 缩放字体 | Ctrl+滚轮 |