无向联通图计数板子

首先,这个太难了,先让我们来求一个简单的:

无向图计数。

一共 \(\frac {n \times (n+1)} 2\) 条可能存在的边,枚举一条边是否存在,就有 \(2^{\frac {n \times (n+1)} 2}\) 个无向图。

回到本题,我们先设 \(f_n\) 是我们要求的 \(n\) 个无向联通图的个数, \(g_n\) 是 \(2^{\frac {n \times (n+1)} 2}\),很明显有:

\[g_n=\sum_{i=1}^n\binom{n-1}{i-1}f_ig_{n-i}
\]

组合数后面的是一个卷积的形式,而组合数本身就是一堆阶乘,这在提示我们使用 EGF,并且本题的模数也是一个 NTT 模数。

\[\frac {g_n} {(n-1)!}=\sum_{i=1}^n \frac {f_i} {(i-1)!} \times \frac {g_{n-i}} {(n-i)!}
\]

然后我们设 \(F(x)\) 是 { \(f_n\) } 的 EGF,\(G(x)\) 是 { \(g_n\) } 的 EGF。

很容易发现:\(g_n=[x^n]G'(x)\),然后就有:

\[G'(x)=F'(x)G(x)
\]
\[\frac {G'(x)} {G(x)}=F'(x)
\]
\[F(x)=\ln G(x)
\]

然后我们就做完了。

贴代码:

#include<cstring>
#include<cstdio>
#define clr(f,len) memset(f,0,(len)<<2)
#define cpy(f,g,len) memcpy(f,g,(len)<<2)
const int G=3,invG=334845270,mod=1004535809,M=7e5+5;
int n,t[M],f[M],inv[M],tor[M];
inline void swap(int&a,int&b){
a^=b^=a^=b;
}
inline void GetRev(int len){
for(int i=0;i<len;++i)t[i]=t[i>>1]>>1|(i&1?len>>1:0);
}
inline void px(int*f,int*g,int len){
for(int i=0;i<len;++i)f[i]=1ll*f[i]*g[i]%mod;
}
inline void der(int*f,int n){
for(int i=1;i<n;++i)f[i-1]=1ll*f[i]*i%mod;
f[n-1]=0;
}
inline void itg(int*f,int n){
for(int i=n;i;--i)f[i]=1ll*f[i-1]*inv[i]%mod;
f[0]=0;
}
inline int pow(int a,int b=mod-2){
int ans=1;
for(;b;b>>=1,a=1ll*a*a%mod)if(b&1)ans=1ll*ans*a%mod;
return ans;
}
void NTT(int*f,bool flag,int n){
int i,k,p,w,w1,len;
for(i=0;i<n;++i)if(i<t[i])swap(f[i],f[t[i]]);
for(p=2;p<=n;p<<=1){
len=p>>1;w1=pow(flag?G:invG,(mod-1)/p);
for(k=0;k<n;k+=p){
w=1;
for(i=k;i<k+len;++i){
int t=1ll*f[i+len]*w%mod;
if((f[i+len]=f[i]-t)<0)f[i+len]+=mod;
if((f[i]=f[i]+t)>mod)f[i]-=mod;
w=1ll*w*w1%mod;
}
}
}
if(flag)return;
int invN=pow(n);
for(i=0;i<n;++i)f[i]=1ll*f[i]*invN%mod;
}
void invp(int*f,int m){
static int b1[M],b2[M],b3[M];
int i,n=1,len;b1[0]=pow(f[0]);
while(n<m)n<<=1;
for(len=2;len<=n;len<<=1){
for(i=0;i<(len>>1);++i)b3[i]=(b1[i]<<1)%mod;
cpy(b2,f,len);
GetRev(len<<1);
NTT(b1,1,len<<1);px(b1,b1,len<<1);
NTT(b2,1,len<<1);px(b1,b2,len<<1);
NTT(b1,0,len<<1);clr(b1+len,len);
for(i=0;i<len;++i)b1[i]=(b3[i]-b1[i]+mod)%mod;
}
cpy(f,b1,m);clr(b1,n<<1);clr(b2,n<<1);clr(b3,n<<1);
}
void lnp(int*f,int n){
static int sav[M];
cpy(sav,f,n);
der(f,n);invp(sav,n);
GetRev(n<<1);
NTT(f,1,n<<1);NTT(sav,1,n<<1);
px(f,sav,n<<1);NTT(f,0,n<<1);
itg(f,n-1);
clr(f+n,n);clr(sav,n);
}
signed main(){
int i,m=1,tmp1,tmp2;
inv[1]=tor[0]=tor[1]=1;
scanf("%d",&n);++n;
while(m<n)m<<=1;
GetRev(m);
for(i=2;i<=m;++i){
inv[i]=1ll*(mod-mod/i)*inv[mod%i]%mod;
tor[i]=1ll*tor[i-1]*i%mod;
}
for(i=0;i<m;++i)f[i]=1ll*pow(2,(1ll*i*(i-1)>>1)%(mod-1))*pow(tor[i])%mod;
lnp(f,m);
printf("%d",1ll*f[n-1]*tor[n-1]%mod);
}

LGP4841题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

随机推荐

  1. listview界面显示

    1.布局写listview      2.找到listview           3.封装新闻数据到list集合中 ,目的是为adapter提供数据展示.     4.封装一个Adapter类继承B ...

  2. Hibernate与JDBC事务整合

    一般大家都会使用Spring声明型事务 transactionAttributes 为 PROPAGATION_REQUIRED Hibernate 使用 HibernateTransactionMa ...

  3. 一键部署nginx 服务

    一键部署nginx服务 老样子安装包都拖到opt里! 脚本如下 source 执行! #!/bin/bash #======编译安装nginx服务====== #安装所需开发包和编译环境.编译器 yu ...

  4. LVS-DR群集

    LVS-DR群集 目录 LVS-DR群集 一.LVS-DR的工作原理 1. LVS-DR数据包流向分析 2. IP包头及数据帧头信息的变化 3. DR模式的特点 4.LVS-DR中的ARP问题 (1) ...

  5. HEAAN库学习

    本文主要学习HEAAN同态库,选择最老的一版:地址,最新版在:位置,HEAAN是CKKS17论文的主要代码复现. 版本 1.地址这是最老的一版,对应的论文CKKS17 2.在1的基础上,实现了boot ...

  6. python——rsa加签名以及分段加密

    借鉴 https://www.cnblogs.com/sammy1989/p/9583965.html 最近请求一个系统,对方要求加密.折腾了一天,使用pycryptodome库,最终代码如下: #! ...

  7. Solution -「LOJ #150」挑战多项式 ||「模板」多项式全家桶

    \(\mathcal{Description}\)   Link.   给定 \(n\) 次多项式 \(F(x)\),在模 \(998244353\) 意义下求 \[G(x)\equiv\left\{ ...

  8. Solution -「多校联训」最小点覆盖

    \(\mathcal{Description}\)   Link.   求含有 \(n\) 个结点的所有有标号简单无向图中,最小点覆盖为 \(m\) 的图的数量的奇偶性.\(T\) 组数据.   \( ...

  9. WMI简介和Event驻留

      WMI (Windows Management Instrumentation,Windows管理规范) 从Windows 2000开始被包含于操作系统后,就一直是Windows操作系统的一部分. ...

  10. LNK善意利用

    lnk   lnk在Windows平台下是快捷方式,可以指向其他目录下的文件,并且可以传递参数.现在有些恶意活动会恶意利用lnk,执行恶意代码.   关于lnk的格式,可以使用010 editor的模 ...