QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#299290 | #5. 在线 O(1) 逆元 | xhgua | Compile Error | / | / | C++14 | 1.0kb | 2024-01-06 18:34:03 | 2024-01-06 18:34:04 |
Judging History
你现在查看的是测评时间为 2024-01-06 18:34:04 的历史记录
- [2024-11-05 21:57:28]
- 管理员手动重测本题所有提交记录
- 测评结果:Compile Error
- 用时:0ms
- 内存:0kb
- [2024-01-06 18:34:04]
- 评测
- 测评结果:Compile Error
- 用时:0ms
- 内存:0kb
- [2024-01-06 18:34:03]
- 提交
answer
#include <inv.h>
#include <array>
#include <vector>
#include <iostream>
using i64 = long long;
constexpr int P = 998244353;
namespace Inversion {
static constexpr int B = (1 << 10), T = (1 << 20);
std::array<int, T + 1> f, p;
std::array<int, T * 3 + 3> buf;
int *I = buf.begin() + T;
void init() {
for (int i = 1; i <= B; i++) {
int s = 0, d = (i << 10);
for (int j = 1; j <= T; j++) {
if ((s += d) >= P) s -= P;
if (s <= T) {
if (!f[j]) f[j] = i, p[j] = s;
}
else if (s >= P - T) {
if (!f[j]) f[j] = i, p[j] = s - P;
}
else {
int t = (P - T - s - 1) / d;
s += t * d, j += t;
}
}
}
I[1] = f[0] = 1;
for (int i = 2; i <= (T << 1); i++)
I[i] = 1ll * (P - P / i) * I[P % i] % P;
for (int i = -1; i >= -T; i--)
I[i] = P - I[-i];
}
int inv(int x) {
return 1ll * I[p[x >> 10] + (x & 1023) * f[x >> 10]] * f[x >> 10] % P;
}
};
void init(int p) {
Inversion::init();
}
int inv(int x) {
return Inversion::inv(x);
}
详细
implementer.cpp: In function ‘int main()’: implementer.cpp:22:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 22 | scanf("%d", &n); | ~~~~~^~~~~~~~~~ answer.code:1:10: fatal error: inv.h: No such file or directory 1 | #include <inv.h> | ^~~~~~~ compilation terminated.