日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

#3456. 城市规划(生成函数,多项式求逆)

發布時間:2023/12/4 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 #3456. 城市规划(生成函数,多项式求逆) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

#3456. 城市規劃

fnf_nfn?nnn個點的的點的簡單無向連通圖數目,gng_ngn?nnn個點的簡單無向圖個數(不要求聯通)。

對于gng_ngn?顯然有gn=2n(n?1)2g_n = 2 ^{\frac{n(n - 1)}{2}}gn?=22n(n?1)?,共有n(n+1)2\frac{n(n + 1)}{2}2n(n+1)?條邊,然后每條邊可選可不選。

我們枚舉111所在的點的連通塊可得:
gn=∑i=1nCn?1i?1fign?i2(2n)=∑i=1n(i?1n?1)fi2(2n?i)2(2n)=∑i=1n(n?1)!(i?1)!(n?i)!fi2(2n?i)2(2n)(n?1)!=∑i=1nfi(i?1)!2(2n?i)(n?i)!設G(x)=∑n=1∞2(2n)(n?1)!xnF(x)=∑n=1∞fn(n?1)!H(x)=∑n=0∞2(2n)n!G(x)=F(x)H(x)F(x)=G(x)H?1(x)構造多項式,多項式求逆,把[xn]項系數乘上(n?1)!即是答案g_n = \sum\limits_{i = 1} ^{n}C_{n - 1} ^{i - 1}f_ig_{n - i}\\ 2 ^{(_2 ^ n)} = \sum_{i = 1} ^{n}(_{i - 1} ^{n - 1})f_i 2 ^{(_2 ^{n - i})}\\ 2 ^{(_2 ^ n)} = \sum_{i = 1} ^{n} \frac{(n - 1)!}{(i - 1)!(n - i)!} f_i 2 ^{(_2 ^{n - i})}\\ \frac{2 ^{(_2 ^ n)}}{(n - 1)!} = \sum_{i = 1} ^{n} \frac{f_i}{(i - 1)!} \frac{2^{(_2 ^{n - i})}}{(n - i)!}\\ 設G(x) = \sum_{n = 1} ^{\infty} \frac{2 ^{(_2 ^n)}}{(n - 1)!} x ^ n\\ F(x) = \sum_{n = 1} ^{\infty} \frac{f_n}{(n - 1)!}\\ H(x) = \sum_{n = 0} ^{\infty} \frac{2 ^{(_2 ^n)}}{n!}\\ G(x) = F(x) H(x)\\ F(x) = G(x)H^{-1}(x)\\ 構造多項式,多項式求逆,把[x ^ n]項系數乘上(n - 1)!即是答案\\ gn?=i=1n?Cn?1i?1?fi?gn?i?2(2n?)=i=1n?(i?1n?1?)fi?2(2n?i?)2(2n?)=i=1n?(i?1)!(n?i)!(n?1)!?fi?2(2n?i?)(n?1)!2(2n?)?=i=1n?(i?1)!fi??(n?i)!2(2n?i?)?G(x)=n=1?(n?1)!2(2n?)?xnF(x)=n=1?(n?1)!fn??H(x)=n=0?n!2(2n?)?G(x)=F(x)H(x)F(x)=G(x)H?1(x)[xn](n?1)!

#include <bits/stdc++.h>using namespace std;const int mod = 1004535809, inv2 = mod + 1 >> 1;namespace Quadratic_residue {struct Complex {int r, i;Complex(int _r = 0, int _i = 0) : r(_r), i(_i) {}};int I2;Complex operator * (const Complex &a, Complex &b) {return Complex((1ll * a.r * b.r % mod + 1ll * a.i * b.i % mod * I2 % mod) % mod, (1ll * a.r * b.i % mod + 1ll * a.i * b.r % mod) % mod);}Complex quick_pow(Complex a, int n) {Complex ans = Complex(1, 0);while (n) {if (n & 1) {ans = ans * a;}a = a * a;n >>= 1;}return ans;}int get_residue(int n) {mt19937 e(233);if (n == 0) {return 0;}if(quick_pow(n, (mod - 1) >> 1).r == mod - 1) {return -1;}uniform_int_distribution<int> r(0, mod - 1);int a = r(e);while(quick_pow((1ll * a * a % mod - n + mod) % mod, (mod - 1) >> 1).r == 1) {a = r(e);}I2 = (1ll * a * a % mod - n + mod) % mod;int x = quick_pow(Complex(a, 1), (mod + 1) >> 1).r, y = mod - x;if(x > y) swap(x, y);return x;} }const int N = 1e6 + 10;int r[N], inv[N], b[N], c[N], d[N], e[N], t[N];int quick_pow(int a, int n) {int ans = 1;while (n) {if (n & 1) {ans = 1ll * a * ans % mod;}a = 1ll * a * a % mod;n >>= 1;}return ans; }void get_r(int lim) {for (int i = 0; i < lim; i++) {r[i] = (i & 1) * (lim >> 1) + (r[i >> 1] >> 1);} }void get_inv(int n) {inv[1] = 1;for (int i = 2; i <= n; i++) {inv[i] = 1ll * (mod - mod / i) * inv[mod % i] % mod;} }void NTT(int *f, int lim, int rev) {for (int i = 0; i < lim; i++) {if (i < r[i]) {swap(f[i], f[r[i]]);}}for (int mid = 1; mid < lim; mid <<= 1) {int wn = quick_pow(3, (mod - 1) / (mid << 1));for (int len = mid << 1, cur = 0; cur < lim; cur += len) {int w = 1;for (int k = 0; k < mid; k++, w = 1ll * w * wn % mod) {int x = f[cur + k], y = 1ll * w * f[cur + mid + k] % mod;f[cur + k] = (x + y) % mod, f[cur + mid + k] = (x - y + mod) % mod;}}}if (rev == -1) {int inv = quick_pow(lim, mod - 2);reverse(f + 1, f + lim);for (int i = 0; i < lim; i++) {f[i] = 1ll * f[i] * inv % mod;}} }void polyinv(int *f, int *g, int n) {if (n == 1) {g[0] = quick_pow(f[0], mod - 2);return ;}polyinv(f, g, n + 1 >> 1);for (int i = 0; i < n; i++) {t[i] = f[i];}int lim = 1;while (lim < 2 * n) {lim <<= 1;}get_r(lim);NTT(t, lim, 1);NTT(g, lim, 1);for (int i = 0; i < lim; i++) {int cur = (2 - 1ll * g[i] * t[i] % mod + mod) % mod;g[i] = 1ll * g[i] * cur % mod;t[i] = 0;}NTT(g, lim, -1);for (int i = n; i < lim; i++) {g[i] = 0;} }void polysqrt(int *f, int *g, int n) {if (n == 1) {g[0] = Quadratic_residue::get_residue(f[0]);return ;}polysqrt(f, g, n + 1 >> 1);polyinv(g, b, n);int lim = 1;while (lim < 2 * n) {lim <<= 1;}get_r(lim);for (int i = 0; i < n; i++) {t[i] = f[i];}NTT(g, lim, 1);NTT(b, lim, 1);NTT(t, lim, 1);for (int i = 0; i < lim; i++) {g[i] = (1ll * inv2 * g[i] % mod + 1ll * inv2 * b[i] % mod * t[i] % mod) % mod;b[i] = t[i] = 0;}NTT(g, lim, -1);for (int i = n; i < lim; i++) {g[i] = 0;} }void derivative(int *a, int *b, int n) {for (int i = 0; i < n; i++) {b[i] = 1ll * a[i + 1] * (i + 1) % mod;} }void integrate(int *a, int n) {for (int i = n - 1; i >= 1; i--) {a[i] = 1ll * a[i - 1] * inv[i] % mod;}a[0] = 0; }void polyln(int *f, int *g, int n) {polyinv(f, b, n);derivative(f, g, n);int lim = 1;while (lim < 2 * n) {lim <<= 1;}get_r(lim);NTT(g, lim, 1);NTT(b, lim, 1);for (int i = 0; i < lim; i++) {g[i] = 1ll * g[i] * b[i] % mod;b[i] = 0;}NTT(g, lim, -1);for (int i = n; i < lim; i++) {g[i] = 0;}integrate(g, n); }void polyexp(int *f, int *g, int n) {if (n == 1) {g[0] = 1;return ;}polyexp(f, g, n + 1 >> 1);int lim = 1;while (lim < 2 * n) {lim <<= 1;}polyln(g, d, n);for (int i = 0; i < n; i++) {t[i] = (f[i] - d[i] + mod) % mod;}t[0] = (t[0] + 1) % mod;get_r(lim);NTT(g, lim, 1);NTT(t, lim, 1);for (int i = 0; i < lim; i++) {g[i] = 1ll * g[i] * t[i] % mod;t[i] = d[i] = 0;}NTT(g, lim, -1);for (int i = n; i < lim; i++) {g[i] = 0;} }/*b存放多項式逆,c存放多項式開根,d存放多項式對數ln,e存放多項式指數exp,t作為中間轉移數組,如果要用到polyln,得提前調用get_inv(n)先預先得到我們想要得到的逆元范圍。 */int h[N], g[N], fac[N], ifac[N], n;void init() {fac[0] = 1;for (int i = 1; i < N; i++) {fac[i] = 1ll * i * fac[i - 1] % mod;}ifac[N - 1] = quick_pow(fac[N - 1], mod - 2);for (int i = N - 2; i >= 0; i--) {ifac[i] = 1ll * ifac[i + 1] * (i + 1) % mod;} }int main() {// freopen("in.txt", "r", stdin);// freopen("out.txt", "w", stdout);// ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);scanf("%d", &n);init();for (int i = 1; i <= n; i++) {g[i] = 1ll * quick_pow(2, 1ll * i * (i - 1) / 2 % (mod - 1)) * ifac[i - 1] % mod;}for (int i = 0; i <= n; i++) {h[i] = 1ll * quick_pow(2, 1ll * i * (i - 1) / 2 % (mod - 1)) * ifac[i] % mod;}polyinv(h, b, n + 1);for (int i = 0; i <= n; i++) {h[i] = b[i];b[i] = 0;}int lim = 1;while (lim <= 2 * n) {lim <<= 1;}get_r(lim);NTT(g, lim, 1);NTT(h, lim, 1);for (int i = 0; i < lim; i++) {g[i] = 1ll * g[i] * h[i] % mod;h[i] = 0;}NTT(g, lim, -1);printf("%d\n", 1ll * g[n] * fac[n - 1] % mod);return 0; }

總結

以上是生活随笔為你收集整理的#3456. 城市规划(生成函数,多项式求逆)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产福利在线观看视频 | 久久国产精品久久久久 | 国产精品第12页 | 大学生av | 日韩在线观看视频一区二区三区 | 韩国午夜激情 | 国产乱子伦精品无码码专区 | 国产无码久久精品 | 亚洲第一天堂在线观看 | 日本三级日本三级日本三级极 | 青青草十七色 | 欧美黄色一级大片 | 999国产精品视频 | 一级黄色a| 国产又黄又硬又粗 | 亚洲成人福利 | 香蕉在线看 | 色成人综合网 | 男人深夜影院 | 日本网站在线播放 | 国产精品性 | 99热精品免费 | 青草超碰 | 国产高清免费在线 | 毛片毛片毛片毛片毛片毛片毛片 | 久久精品一区二区国产 | 夜夜躁狠狠躁日日躁av | 国产高清二区 | 日本肉体xxxⅹ裸体交 | 免费无遮挡网站 | 久久综合影视 | 又黄又爽的视频在线观看 | 丰满人妻一区二区三区性色 | 国产精品美女久久久久久 | 亚洲精品成人网 | 国产自偷自拍视频 | 日本在线一 | 农民工hdxxxx性中国 | 新婚若妻侵犯中文字幕 | 在线播放国产精品 | 国产精品免费av一区二区三区 | 成人在线免费小视频 | 国产九九九精品 | 欧美精品一区二区三区四区 | 青青草免费在线 | 成年人视频在线免费看 | 人妻一区二区视频 | 操丝袜美女视频 | 欧美色涩 | 在线观看av资源 | 欧美日韩黄色网 | 日韩电影一区二区在线观看 | 欧美抠逼视频 | 六月丁香久久 | 中文字幕资源站 | 理论片亚洲 | 无码人妻精品一区二区三区温州 | 少妇吹潮| 2021亚洲天堂| 欧美日韩一级在线观看 | 亚洲成人欧美 | 亚洲一级中文字幕 | 午夜天堂在线 | 欧美日韩成人在线视频 | 大尺度舌吻呻吟声 | 麻豆传媒在线观看视频 | 麻豆天天躁天天揉揉av | 亚洲高清视频在线观看 | 天天干夜夜添 | 美女网站在线免费观看 | 婷婷在线视频 | 影音先锋精品 | 免费av一区二区三区 | 在线观看成人 | 欧美成人做爰大片免费看黄石 | 偷拍综合网 | 日剧大尺度床戏做爰 | 亚洲国产成人在线视频 | 日韩精品亚洲精品 | 日韩一区二区毛片 | av不卡在线播放 | 毛片无码免费无码播放 | 人妻无码一区二区三区免费 | 先锋影音一区二区 | 天堂av亚洲av国产av电影 | 成人黄色大片在线观看 | 综合久久一区二区 | 久久久久久国产精品免费 | av片网| 91沈先生在线 | 三上悠亚中文字幕在线播放 | 国产老女人精品毛片久久 | 日本精品久久久久久 | 欧美影视 | 最新av在线| 国产三级av在线播放 | 色婷婷av一区二区三区四区 | sm乳奴虐乳调教bdsm | 午夜精品网站 |