QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#479132 | #5. 在线 O(1) 逆元 | A_programmer# | 100 ✓ | 5213ms | 26204kb | C++17 | 1.0kb | 2024-07-15 15:17:13 | 2024-11-05 22:00:17 |
Judging History
answer
#include "inv.h"
#include <bits/stdc++.h>
using namespace std;
const int B = 1 << 10, B2 = 1 << 20;
int Inv[B2 << 2], mod;
int U[B2 | 10], vl[B2 | 10];
int* iv;
void init(int P)
{
iv = Inv + B2;
iv[1] = 1; mod = P;
for (int i = 2; i <= (B2 << 1); i++) iv[i] = 1ll * (P - P / i) * iv[P % i] % P;
for (int i = 1; i <= B2; i++) iv[-i] = mod - iv[i];
U[0] = 1;
for (int u = 1; u <= B; u++)
{
int uB = u << 10, sum = 0;
for (int k = 1; k <= B2; k++)
{
sum = ((sum += uB) >= P ? sum - P : sum);
if (sum <= B2)
{
if (!U[k]) U[k] = u, vl[k] = sum;
}
else if (sum >= P - B2)
{
if (!U[k]) U[k] = u, vl[k] = sum - P;
}
else
{
int nxt = (P - B2 - sum - 1) / uB;
k += nxt, sum += nxt * uB;
}
}
}
}
int inv(int x) { return 1ll * iv[vl[x >> 10] + (x & 1023) * U[x >> 10]] * U[x >> 10] % mod; }
詳細信息
Pretests
Final Tests
Test #1:
score: 10
Accepted
time: 33ms
memory: 25144kb
Test #2:
score: 20
Accepted
time: 604ms
memory: 26204kb
Test #3:
score: 30
Accepted
time: 2040ms
memory: 24984kb
Test #4:
score: 20
Accepted
time: 3157ms
memory: 24864kb
Test #5:
score: 20
Accepted
time: 5213ms
memory: 25740kb