Educational Codeforces Round 87 (Rated for Div. 2)A. Alarm Clock

题目链接:http://codeforces.com/contest/1354/problem/A

problom description

Polycarp has spent the entire day preparing problems for you. Now he has to sleep for at least a
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 b
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 a
minutes in total, then he sets his alarm to go off in c minutes after it is reset and spends d
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 c
minutes and tries to fall asleep for d
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 t (1≤t≤1000
) — the number of testcases.
The only line of each testcase contains four integers a,b,c,d
(1≤a,b,c,d≤109) — 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.

Example
Input
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
Output
27
27
9
-1
1
6471793358578060125049

Note

In the first testcase Polycarp wakes up after 3
minutes. He only rested for 3 minutes out of 10 minutes he needed. So after that he sets his alarm to go off in 6 minutes and spends 4 minutes falling asleep. Thus, he rests for 2 more minutes, totaling in 3+2=5 minutes of sleep. Then he repeats the procedure three more times and ends up with 11 minutes of sleep. Finally, he gets out of his bed. He spent 3 minutes before the first alarm and then reset his alarm four times. The answer is 3+4⋅6=27
.
The second example is almost like the first one but Polycarp needs 11
minutes of sleep instead of 10. However, that changes nothing because he gets 11
minutes with these alarm parameters anyway.
In the third testcase Polycarp wakes up rested enough after the first alarm. Thus, the answer is b=9.
In the fourth testcase Polycarp wakes up after 5
minutes. Unfortunately, he keeps resetting his alarm infinitely being unable to rest for even a single minute

    #include <iostream>
    #include <cmath>
    using namespace std;
    typedef long long ll;
    int main()
    {
        ll T,a,b,c,d,s,cnt,k;
        cin>>T;
        while(T--)
        {
            cin>>a>>b>>c>>d;
            if(b>=a)
                cout<<b<<endl;
            else if(d>=c)
                cout<<-1<<endl;
            else
            {
                s=a-b;
                k=c-d;
                cnt=ceil(s/double(k));
                cout<<b+cnt*c<<endl;
            }
        }
        return 0;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值