Time Exceeded
Code
#include <cstdio>
using ll = long long;
ll sum_floor_div(ll N, ll M) {
ll result = 0;
ll d = 1;
while (d <= M) {
ll q = N / d;
ll R = N / q;
if (R > M) R = M;
result += q * (R - d + 1);
d = R + 1;
}
return result;
}
int main() {
int T; scanf("%d", &T);
while (T--) {
ll N; scanf("%lld", &N);
if (N == 1) {
puts("0");
continue;
}
ll ans = sum_floor_div(N, N - 1) - (N - 1);
printf("%lld\n", ans);
}
return 0;
}
Information
- Submit By
- Type
- Submission
- Problem
- P1207 D2. GCD equal Absolute Value (Hard Version)
- Contest
- Educational Round 1
- Language
- C++17 (G++ 13.2.0)
- Submit At
- 2025-07-14 16:23:54
- Judged At
- 2025-07-14 16:23:54
- Judged By
- Score
- 5
- Total Time
- ≥1096ms
- Peak Memory
- ≥428.0 KiB