下降幂多项式
下降幂多项式
下降幂的定义
下降幂\(\text{Falling Factorial}\)
下降幂多项式\(\text{Falling Factorial Polynomial}\)下面简称\(\text{FFP}\)
\(x\)的\(n\)阶下降幂\(x^{\underline n}=\prod_0^{n-1}(x-i) = \frac{x!}{(x-n)!}\)
一个下降幂多项式\(F(x)=\sum a_ix^{\underline i}\)
快速求解\(x^{\underline n}\)的展开形式
\(x^{\underline{n}}=x(x-1)\cdots (x-n+1)\)
考虑倍增求解,假设已知\(F(x)=x^{\underline{n}}\)
要求\(G(x)=x^{\underline{2n}}\)
显然\(G(x)=F(x)F(x-n)\)
而\(\begin{aligned} F(x-n)=\sum_{i=0}^{n} [x^i]F(x) \cdot (x-n)^i\end{aligned}\)
用一次卷积处理这个二项展开即可
复杂度为\(O(n\log n)\)
FFP与其点值的\(\text{EGF}\)
点值的\(\text{EGF}\)为\(\begin{aligned} EGF(F(x))=\sum_0^{\infty}\frac{F(i)x^i }{i!}\end{aligned}\)
\(\begin{aligned}EGF(F(x))=\sum_{i=0}^{\infty}\frac{x^i}{i!}\sum_{j=0}^{n} \frac{i!}{(i-j)!}\cdot F_j\end{aligned}\)
\(\begin{aligned}EGF(F(x))=\sum_{i=0}^{\infty}x^i \sum_{j=0}^{n} \frac{1}{(i-j)!}\cdot F_j\end{aligned}\)
换一下顺序
\(\begin{aligned}EGF(F(x))=\sum_{i=0}^{n} F_i \sum_{j=i}^{\infty}\frac{1}{(j-i)!} x^j\end{aligned}\)
\(\begin{aligned}EGF(F(x))=\sum_{i=0}^{n} F_i \cdot x^i \sum_{j=0}^{\infty}\frac{1}{j!} x^j\end{aligned}\)
\(\begin{aligned}EGF(F(x))=\sum_{i=0}^{n} F_i \cdot x^i e^x\end{aligned}\)
那么直接和\(e^x\)卷积就可以得到\(F(x)\)的\(\text{EGF}\)
Tips: \(e^x\)直接带入展开式\(\begin{aligned} e^{ax}=\sum_0^{\infty}\frac{(ax)^i}{i!} \end {aligned}\)
如果要从\(\text{EGF}\)得到\(F(x)\)
\(\begin{aligned}EGF(F(x))=\sum_{i=0}^{n} F_i \cdot x^ie^x\end{aligned}\)
\(\begin{aligned} F_i=\frac{EGF(F(x))}{x^ie^x} \end{aligned}\)
那么就直接卷上\(e^{-x}\)就可以了
即可以通过简单卷积完成\(\text{FFP} \Longleftrightarrow \text{EGF}\)的转化
FFP卷积
求出\(\text{EGF}\),然后点值对应相乘(注意乘完之后要补上一个\(i!\)),最后再反求\(F(x)\)
Tips: 下面的知识恐怕需要先学多点求值/快速插值
多项式转FFP
带入\(0,\cdots n-1\),多点求值得到\(\text{FFP}\)点值的\(EGF\),然后求得到\(\text{FFP}\)
FFP转多项式
求出\(F(x)\)的\(EGF\),然后带入前\(n\)项的值,快速插值回来即可
由于\(x_i\)是连续的,所以不需要再多点求值求解\(\prod\frac{1}{x_i-x_j}\),可以直接阶乘得到
关于上升幂
\(x^{\overline n}=\frac{(x+n-1)!}{(x-1)!}=x(x+1)(x+2)\cdots(x+n-1)\)
容易发现的是\(x^{\overline n}=(-x)(-((-x)-1))(-((-x)-2))\cdots (-(-x-(n-1)))=(-1)^n (-x)^{\underline{n}}\)
所以上升幂多项式与普通多项式的转化 可以认为是上面的点值变成了\(0,-1,\cdots ,-(n-1)\),奇数项系数取反