多项式 Polynomials

多项式定理

定义为:

(kxi)n=ni=nk=0(nn1,n2,,nk)xini

其中:

(nn1,n2,,nk)=n!ni!

它的具象解释是从 n 个球中,依次取出 n1,n2,,nk 个球(不放回)的总方案数。

广义二项式定理 Generalized Binomial Theorem

由于做题时可能会出现形如 (ax+by)α,αR 形式的多项式,对于此种多项式,我们没有办法用普通的二项式定理进行展开,为此,我们引入广义二项式系数与广义二项式定理:

广义二项式系数:

(αk)=α(α1)(αk1)k!=αkk!,αR,kN

广义二项式定理:

(x+y)α=k=0(αk)xαkyk

有了以上两个定义,我们就可以很轻松地对 11x,11x114514 等等二项式进行展开了。

求广义二项式系数时,我们可能会遇到上为分数,下为整数的情况。通常,化简时会用到双阶乘:

α!!={1×3×5××α, α 2×4×6××α, α 

简而言之,一个正整数的双阶乘就是不超过这个正整数且与它有相同奇偶性的所有正整数乘积

生成函数 Generating Function

本文将会提及的生成函数分为两种:普通型生成函数指数型生成函数

普通型生成函数 Ordinary Generating Function

普通型生成函数,简称 OGF。一个数列 A(x) 的 OGF 定义为:

F(x)=nA(n)xn

指数型生成函数 Exponential Generating Function

指数型生成函数,简称 EGF。一个数列 A(x) 的 EGF 定义为:

F^(x)=nA(n)xnn!

常见的 EGF 可以化简(其实就是 ex 的泰勒展开式的各种结合):

1+x+x22!+=ex

1+x22!+x44!+=ex+ex2

x+x33!+x55!+=exex2

一般来说,若题设中要求无标号计数,则用 OGF,否则用 EGF。

Examples:

P2000 拯救世界

把两个人的十条序列写出 OGF,乘在一起,得到:

(n+1)(n+2)(n+3)(n+4)24

用 FFT 或 NTT 求出即可。

P2012 拯救世界2

注意到题面中描述的是“基因序列”,应是有序的,所以写出 EGF 得:

e12x4e8x+6e4x4+e4x256

最后取 n 次项系数即可,注意算出 EGF 时分母有 n!,所以取系数时乘回去,得到:

12n4×8n+6×4n(4)n256 mod 109

生成函数还可以用来求数列的通项公式,如 Fibonacci 数,Catalan 数等经典数列。

多项式操作 Polynomial Operations

多项式求逆

定义:若一个多项式 B(x) 为另一个多项式 A(x) 的逆,则:

AB=1,i=0nAiBni=[n=0]

推得:

Bn=1A0i=1nAiBni

递推求解。

多项式求 ln

定义:若一个多项式 B(x) 为另一个多项式 A(x) 的模 xn 意义下的 ln,系数对质数取模,则:

B(x)lnA(x)

其中,lnA(x) 比较不好理解,为此,我们对多项式两边求导得到:

B(x)=A(x)A(x)

移项:

B(x)A(x)=A(x)

推出:

Bn+1=An+1(n+1)i=1niBiAn+1i(n+1)A0

可以用 FFT 求。

多项式 exp

定义:若一个多项式 B(x) 为另一个多项式 A(x) 的模 xn 意义下的 exp,系数对质数取模,则:

B(x)exp(A(x))eA(x)

同样地,因为 eA(x) 很难看,所以先对两边取 ln 再求导:

B(x)=B(x)A(x)

推出:

Bn+1=1n+1i=0nBniAi+1(i+1)

Examples:

(基环树计数)求包含 n 个顶点,n 条边的连通无向图有多少个。每个点带标号。不允许重边与自环。

根据 Cayley 定理,n 个点有标号有根树数量为 nn1,所以每棵树的 EGF 为:

A(x)=n1nn1xnn!

所以答案的生成函数,k 为环的大小:

F(x)=12n3Ak(x)k=12ln(1A(x))A(x)2A2(x)4

FFT 或 NTT 求出 ln(1A(x))A2(x),时间复杂度 O(nlogn)

本文作者:Cuset_VoidAldehyde

本文链接:https://www.cnblogs.com/CusetVoidAldehyde/p/18173699

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   Cuset_VoidAldehyde  阅读(14)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起