和 上一题 几乎一样,双倍经验!
#include <lastweapon/poly>
using namespace lastweapon;
Poly H, HH;
int n;
LL C2(LL n) {
return n*(n-1)/2;
}
int b(int n) {
Poly A(n); REP(i, n) A[i] = H[i] * -n;
Poly B = HH.mod(n) * A.exp();
return (B[n-1] * fac[n-1] / n).x;
}
int main(){
#ifndef ONLINE_JUDGE
freopen("in.txt", "r", stdin);
#endif
vector<int> q; DO(5) q.PB(RD()); n = *max_element(ALL(q)) + 1;
Poly C(n), G(n); REP(i, n) G[i] = Mint(2).pow(C2(i)), G[i] *= invFac[i]; C = G.log();
H = C; REP(i, n) H[i] *= i; HH = H.D();
for (auto i: q) printf("%d\n", b(i));
}




Alca
Amber
Belleve Invis
Chensiting123
Edward_mj
Fotile96
Hlworld
Kuangbin
Liyaos
Lwins
LYPenny
Mato 完整版
Mikeni2006
Mzry
Nagatsuki
Neko13
Oneplus
Rukata
Seter
Sevenkplus
Sevenzero
Shirleycrow
Vfleaking
wangzhpp
Watashi
WJMZBMR
Wywcgs
XadillaX
Yangzhe
三途川玉子
About.me
Vijos
