QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#106146 | #5. 在线 O(1) 逆元 | zhoukangyang | 100 ✓ | 4851ms | 40312kb | C++17 | 1.2kb | 2023-05-16 18:31:44 | 2024-11-05 21:49:48 |
Judging History
answer
#include<bits/stdc++.h>
#include "inv.h"
#define L(i, j, k) for(int i = (j); i <= (k); ++i)
#define R(i, j, k) for(int i = (j); i >= (k); --i)
#define ll long long
#define vi vector < int >
#define sz(a) ((int) (a).size())
#define ll long long
#define ull unsigned long long
#define me(a, x) memset(a, x, sizeof(a))
#define eb emplace_back
using namespace std;
const int B = 1024, buf = 3, mod = 998244353, N = 6.1e6 + 7;
int K, ml[N], iv[N], dis[N];
int Inv(int x) {
return x < N ? iv[x] : (ll) Inv(mod % x) * (mod - mod / x) % mod;
}
int inv(int w) {
int d = w >> 10;
return !ml[d] ? Inv(w) : (ll) iv[w * ml[d] - dis[d]] * ml[d] % mod;
}
void init(int rp) {
K = mod / B;
L(fb, 1, B * buf) {
int cur = 0, Add = fb * B;
for(int p = 0; p <= K; ) {
if(cur <= K * buf) {
ml[p] = fb;
cur += Add, ++p;
} else {
int A = (mod - cur + Add - 1) / Add;
cur += A * Add, p += A;
}
if(cur >= mod) cur -= mod;
}
}
int count = 0;
L(i, 1, K) if(ml[i]) dis[i] = (ll) ml[i] * i * B / mod * mod, ++count;
// cout << 1. * count / K << endl;
iv[1] = 1;
L(i, 2, N - 1) iv[i] = (ll) iv[mod % i] * (mod - mod / i) % mod;
}
詳細信息
Pretests
Final Tests
Test #1:
score: 10
Accepted
time: 50ms
memory: 39920kb
Test #2:
score: 20
Accepted
time: 283ms
memory: 38772kb
Test #3:
score: 30
Accepted
time: 1863ms
memory: 39876kb
Test #4:
score: 20
Accepted
time: 4669ms
memory: 37576kb
Test #5:
score: 20
Accepted
time: 4851ms
memory: 40312kb