1
0
Fork 0

Add number/examples/factorial-inverse-in-linear.cc

Signed-off-by: subcrip <contact@subc.rip>
This commit is contained in:
subcrip 2024-10-30 16:34:17 +08:00
parent 5f5a22ec7a
commit 68ccdc21fa
1 changed files with 20 additions and 0 deletions

View File

@ -0,0 +1,20 @@
constexpr int N = 3e6 + 10;
ll fact[N], factrev[N + 1], s[N + 1];
void prep() {
fact[0] = factrev[0] = 1;
for (int i = 1; i < N; ++i) {
fact[i] = (fact[i - 1] * i) % MDL;
}
s[0] = 1;
for (int i = 1; i <= N; ++i) {
s[i] = s[i - 1] * fact[i - 1] % MDL;
}
factrev[N] = inverse(s[N], MDL);
for (int i = N; i; --i) {
factrev[i - 1] = factrev[i] * fact[i - 1] % MDL;
}
for (int i = 0; i < N; ++i) {
factrev[i] = factrev[i + 1] * s[i] % MDL;
}
}