結果
問題 | No.1276 3枚のカード |
ユーザー |
![]() |
提出日時 | 2020-10-30 23:19:20 |
言語 | C++14 (gcc 11.2.0 + boost 1.78.0) |
結果 |
AC
|
実行時間 | 651 ms / 2,000 ms |
コード長 | 2,732 bytes |
コンパイル時間 | 1,368 ms |
使用メモリ | 6,332 KB |
最終ジャッジ日時 | 2023-02-21 16:09:58 |
合計ジャッジ時間 | 21,992 ms |
ジャッジサーバーID (参考情報) |
judge12 / judge15 |
テストケース
テストケース表示入力 | 結果 | 実行時間 使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
6,204 KB |
testcase_01 | AC | 2 ms
6,180 KB |
testcase_02 | AC | 2 ms
6,208 KB |
testcase_03 | AC | 1 ms
6,192 KB |
testcase_04 | AC | 1 ms
6,264 KB |
testcase_05 | AC | 1 ms
6,204 KB |
testcase_06 | AC | 1 ms
6,176 KB |
testcase_07 | AC | 1 ms
6,208 KB |
testcase_08 | AC | 1 ms
6,192 KB |
testcase_09 | AC | 1 ms
6,320 KB |
testcase_10 | AC | 547 ms
6,204 KB |
testcase_11 | AC | 257 ms
6,192 KB |
testcase_12 | AC | 327 ms
6,172 KB |
testcase_13 | AC | 343 ms
6,192 KB |
testcase_14 | AC | 30 ms
6,188 KB |
testcase_15 | AC | 276 ms
6,188 KB |
testcase_16 | AC | 598 ms
6,212 KB |
testcase_17 | AC | 319 ms
6,252 KB |
testcase_18 | AC | 241 ms
6,272 KB |
testcase_19 | AC | 395 ms
6,256 KB |
testcase_20 | AC | 229 ms
6,196 KB |
testcase_21 | AC | 239 ms
6,280 KB |
testcase_22 | AC | 609 ms
6,256 KB |
testcase_23 | AC | 26 ms
6,272 KB |
testcase_24 | AC | 373 ms
6,324 KB |
testcase_25 | AC | 123 ms
6,176 KB |
testcase_26 | AC | 463 ms
6,256 KB |
testcase_27 | AC | 532 ms
6,192 KB |
testcase_28 | AC | 513 ms
6,176 KB |
testcase_29 | AC | 292 ms
6,280 KB |
testcase_30 | AC | 55 ms
6,164 KB |
testcase_31 | AC | 25 ms
6,192 KB |
testcase_32 | AC | 132 ms
6,256 KB |
testcase_33 | AC | 8 ms
6,176 KB |
testcase_34 | AC | 91 ms
6,252 KB |
testcase_35 | AC | 85 ms
6,284 KB |
testcase_36 | AC | 6 ms
6,208 KB |
testcase_37 | AC | 79 ms
6,332 KB |
testcase_38 | AC | 52 ms
6,204 KB |
testcase_39 | AC | 139 ms
6,200 KB |
testcase_40 | AC | 580 ms
6,208 KB |
testcase_41 | AC | 478 ms
6,280 KB |
testcase_42 | AC | 519 ms
6,252 KB |
testcase_43 | AC | 452 ms
6,280 KB |
testcase_44 | AC | 645 ms
6,188 KB |
testcase_45 | AC | 584 ms
6,212 KB |
testcase_46 | AC | 583 ms
6,212 KB |
testcase_47 | AC | 479 ms
6,212 KB |
testcase_48 | AC | 459 ms
6,196 KB |
testcase_49 | AC | 522 ms
6,200 KB |
testcase_50 | AC | 576 ms
6,268 KB |
testcase_51 | AC | 495 ms
6,168 KB |
testcase_52 | AC | 423 ms
6,272 KB |
testcase_53 | AC | 498 ms
6,172 KB |
testcase_54 | AC | 576 ms
6,196 KB |
testcase_55 | AC | 440 ms
6,248 KB |
testcase_56 | AC | 427 ms
6,264 KB |
testcase_57 | AC | 550 ms
6,208 KB |
testcase_58 | AC | 572 ms
6,192 KB |
testcase_59 | AC | 499 ms
6,184 KB |
testcase_60 | AC | 651 ms
6,280 KB |
ソースコード
#include<bits/stdc++.h> using namespace std; using LL = long long; using ULL = unsigned long long; #define rep(i,n) for(int i=0; i<(n); i++) template<ULL M> struct static_modint { ULL x; static_modint(ULL val = 0) : x(val) {} static_modint& operator+=(static_modint r) { x += r.x; if (x >= M) x -= M; return *this; } static_modint operator+(static_modint r) const { static_modint res = x; return res += r; } static_modint& operator-=(static_modint r) { x += M - r.x; if (x >= M) x -= M; return *this; } static_modint operator-(static_modint r) const { static_modint res = x; return res -= r; } static_modint& operator*=(static_modint r) { x = x * r.x % M; return *this; } static_modint operator*(static_modint r) const { return static_modint(x * r.x % M); } static_modint pow(ULL r) const { if (r == 0) return static_modint(1); static_modint res = pow(r / 2); res *= res; if (r % 2) res *= *this; return res; } static_modint& operator/=(static_modint r) { *this *= r.pow(M - 2); return *this; } static_modint operator/(static_modint r) const { return *this * (r.pow(M - 2)); } ULL& operator*() { return x; } const ULL& operator*() const { return x; } bool operator==(static_modint r) const { return x == r; } bool operator!=(static_modint r) const { return x != r; } }; static const ULL M = 1000000007; using MLL = static_modint<M>; vector<ULL> NMul; // number of greater multiples vector<ULL> RNMul; // number of integers that has just the number of greater multiples ULL F(ULL n) { ULL ans = 0; for (ULL i = 1; i * i <= n; i++) { ULL f = n / i; if (f * f > n) ans += f - 1; } for (ULL i = 1; i * i <= n; i++) ans += (i - 1) * (n / i - n / (i + 1)); ans -= n - 1; return ans; } int main() { ULL N; cin >> N; NMul = { 0 }; RNMul = {}; for (ULL i = 1; i * i <= N; i++) { NMul.push_back(N / i - 1); if (NMul.back() * NMul.back() <= N) NMul.pop_back(); } for (ULL i = 0; i * i <= N; i++) { RNMul.push_back(N / (i + 1) - N / (i + 2)); } MLL ans = MLL(N % M) * MLL((N - 1) % M) * MLL((N - 2) % M); for (ULL i = 1; i < NMul.size(); i++) { MLL tmp = 0; tmp += (NMul[i] * (NMul[i] - 1) % M); tmp += ((N - 2) * (N - 1 - NMul[i]) % M); MLL Fx = F(NMul[i] + 1) % M; tmp += Fx; ans -= tmp; } for (ULL i = 0; i < RNMul.size(); i++) { MLL tmp = 0; tmp += (i * (i - 1) % M); tmp += ((N - 2) * (N - 1 - i) % M); MLL Fx = F(i + 1) % M; tmp += Fx; tmp *= RNMul[i]; ans -= tmp; } cout << *ans << endl; return 0; }