您的位置:首页 > 其它

HZAU 1001 Handing Out Candies

2016-05-14 14:32 621 查看
原题

这题还是蛮难的 值得细细品味

#include <climits>
#include <cmath>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <set>
using namespace std;
void solve()
{
long long n, k;
cin >> n >> k;
long i = k / n;
long l = k / (i + 1) + 1;
long r = n;
long long ans = 0;
while (l > 0) {
ans += (k * (r - l + 1) - i * (l + r) * (r - l + 1) / 2);
if (l == 1) break;
i = k / (l - 1);
l = k / (i + 1) + 1;
r = k / i;
}
cout << ans << endl;
}
int main()
{
//  freopen("input.txt", "r", stdin);
int t;
scanf("%d", &t);
for (int i = 0; i < t; i++) {
solve();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: