QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#165818 | #6741. Digit | mendicillin2 | AC ✓ | 1798ms | 9656kb | C++17 | 2.9kb | 2023-09-05 22:02:19 | 2023-09-05 22:02:19 |
Judging History
answer
#include <bits/extc++.h>
using namespace std;
template <class T> int sz(T&& a) { return int(size(forward<T>(a))); }
template <class T> using vc = vector<T>;
template <class T> using vvc = vc<vc<T>>;
using ll = int64_t;
using vi = vc<int>;
using uint = uint32_t;
using ull = uint64_t;
mt19937 mt(chrono::steady_clock::now().time_since_epoch().count());
template <class F>
struct ycr {
F f;
template <class T> explicit ycr(T&& f_) : f(forward<T>(f_)) {}
template <class... Args> decltype(auto) operator()(Args&&... args) {
return f(ref(*this), forward<Args>(args)...);
}
};
template <class F> decltype(auto) yc(F&& f) {
return ycr<decay_t<F>>(forward<F>(f));
}
struct custom_hash {
static const uint64_t c = ll(4e18*acos(0))+71;
const ll z = mt();
ll operator ()(ll x) const { return __builtin_bswap64((x^z)*c); }
};
template <class K, class V>
using hash_map = __gnu_pbds::gp_hash_table<K, V, custom_hash>;
template <class K>
using hash_set = hash_map<K, __gnu_pbds::null_type>;
template <class T> T pow(T a, ll b) {
assert(b >= 0);
T r = 1; while (b) { if (b & 1) r *= a; b >>= 1, a *= a; } return r;
}
template <uint mod> struct mint {
static constexpr uint m = mod;
uint v;
mint() : v(0) {}
mint(ll a) { s(uint(a % m + m)); }
mint& s(uint a) { v = a < m ? a : a-m; return *this; }
mint operator- () const {
mint res;
res.v = v ? m-v : 0;
return res;
}
friend mint inv(const mint& n) { return pow(n, m-2); }
mint& operator += (const mint& o) { return s(v + o.v); return *this; }
mint& operator -= (const mint& o) { return s(v + m - o.v); return *this; }
mint& operator *= (const mint& o) { v = uint(ull(v) * o.v % m); return *this; }
mint& operator /= (const mint& o) { return v *= inv(o); }
friend mint operator + (const mint& a, const mint& b) { return mint(a) += b; }
friend mint operator - (const mint& a, const mint& b) { return mint(a) -= b; }
friend mint operator * (const mint& a, const mint& b) { return mint(a) *= b; }
friend mint operator / (const mint& a, const mint& b) { return mint(a) /= b; }
};
using num = mint<998244353>;
int main() {
ios_base::sync_with_stdio(false), cin.tie(nullptr);
const int L = 123;
vector<num> invs(L);
for (int a = 1; a < L; a++) {
invs[a] = inv(num(a));
}
int T; cin >> T;
while (T--) {
ull n, N; cin >> n >> N;
hash_map<ull, num> dp;
num ans = yc([&](auto self, ull cur) -> num {
if (cur > N) return 0;
if (dp.find(cur) != dp.end()) {
return dp[cur];
}
int cnt = 0;
int cnt_0 = 0;
num rhs = 0;
{
ull a = cur;
while (a > 0) {
int d = int(a % 10);
cnt++;
if (d == 0) {
cnt_0++;
} else {
rhs += self(cur * (d+1));
}
a /= 10;
}
}
assert(cnt - cnt_0 > 0);
num res = (num(cnt) + rhs) * invs[cnt - cnt_0];
return dp[cur] = res;
})(n);
cout << ans.v << '\n';
}
}
详细
Test #1:
score: 100
Accepted
time: 1ms
memory: 3656kb
input:
3 1 10 1 100 1 1000
output:
3 4 942786340
result:
ok 3 number(s): "3 4 942786340"
Test #2:
score: 0
Accepted
time: 1025ms
memory: 9516kb
input:
200 6093 473302679260560320 8548 407261659389622784 643 187875386337017408 8115 804844129595563776 3331 457909423622471360 8554 769878068775393152 2189 248771553604839360 7395 486014798136226944 8022 834223266052054400 9218 291007794161740672 8431 738787973811775616 1829 183591119896739584 816 23406...
output:
401752224 25564055 349247348 24571488 454552241 293307892 841921314 316896313 340265070 679232017 880794571 220757927 783764236 593413719 368463075 771186516 780654585 3628414 827863355 617858224 868927625 446978548 351494058 130284374 125073939 38120850 748432314 277667083 183850680 235708406 51111...
result:
ok 200 numbers
Test #3:
score: 0
Accepted
time: 152ms
memory: 6368kb
input:
200 3043059018339257 22277869996577613 9995869516 503712331451 389592 72563932968 3520234478258 476959582208156 77586585 711120211545804458 77846354 2243822883730937 9937954107 8390895135555 39032 603567 7739 4682236745217490 12277973519 7136059697857236 7264388 607094625 66205992799 4030219735546 3...
output:
108920162 651706276 549514920 440563412 796578996 851857830 191543780 540715694 549223125 380090491 553492005 247956062 582309209 67430878 174114881 1 669072219 981051601 561639793 304668111 397423058 607062211 8458982 479445466 287831358 913943402 533482140 801644611 519995972 239199505 587671914 2...
result:
ok 200 numbers
Test #4:
score: 0
Accepted
time: 1570ms
memory: 9616kb
input:
200 58 999999999999997440 75 999999999999999872 52 999999999999997696 85 999999999999999360 12 999999999999999488 77 999999999999999232 80 999999999999999232 36 999999999999997184 51 999999999999998720 79 999999999999997440 76 999999999999998592 90 999999999999997696 32 999999999999998336 67 9999999...
output:
603520497 574767370 222266238 241598642 627473669 958322466 776467011 836867165 317725053 772230956 80008248 170 205889745 956913345 252066713 183389093 251365357 387390363 836867165 660512518 265265911 574767370 317725053 620530996 15655429 247241569 103698881 940321220 960908253 960908253 66051251...
result:
ok 200 numbers
Test #5:
score: 0
Accepted
time: 493ms
memory: 9632kb
input:
200 509411 999999999999999232 33801448 999999999999998720 65 999999999999998208 6 999999999999997184 404287 999999999999999360 800418816395 999999999999999232 44589090134507 999999999999997312 2008080 999999999999999360 13 999999999999998976 87 999999999999999872 206327851576605 999999999999999744 3...
output:
883813861 221710219 620530996 252066714 168038945 932330901 77414612 443356611 1883978 608670663 568648025 891202485 151357997 793825022 180372901 749235099 391331669 890726608 103698881 258627374 738512765 18273750 771644777 916674174 110687232 890972839 85823452 799141196 739829892 675630993 44879...
result:
ok 200 numbers
Test #6:
score: 0
Accepted
time: 1798ms
memory: 9656kb
input:
200 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 1000000000000000000 1 10000000...
output:
252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 252066716 ...
result:
ok 200 numbers