Educational Codeforces Round 78 (Rated for Div. 2) B - A and B(思维)

😢 😢 😢
题意:第 i 步可以挑一个数字加 i ,问你最少多少步能让两个数字相等

假设刚开始两个数字相等,然后一个数字向前走了abs(b-a)步,由等差数列求和公式,这时候我们贪心的让另外一个数字走大于等于abs(b - a)的最小步数,然后如果两数相等必须满足走的步数之和%2=0(这里也可以反映为什么要大于abs(b-a),因为就算小于的时候%2=0,一开始的abs(b-a)是不可分配的,只能靠后来走的步数的重新分配使两数相等,然而如何分配的过程我们并不关心)

还有就是昨天真的好困QAQ。。。打的心态最崩的一场没跑了

void solve()
{
    ll a, b;cin >> a >> b;
    ll c = max(a, b) - min(a, b);
    int i;
    for (i = 0;; i++)  if (c <= (i * (i + 1)) / 2) break;
    ll m = (i * (i + 1)) / 2;
    while ((m + c) % 2) i++,m = (i * (i + 1)) / 2;
    cout << i << endl;
    return;
}
int main()
{
    //fast;
    int t;cin >> t;
    while (t--)
        solve();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值