【洛谷p4705】玩游戏

题目大意

一个长度为\(n\)的序列\(a\)和长度为\(m\)的序列\(b\),对于\(1..t\)的每个\(k\),求

\[\frac{1}{nm}\sum_{x=1}^n \sum_{y=1}^m (a_x+b_y)^k \]

\(n,m,t\leq 10^5\)

题解

\[\begin{aligned} ans&=\frac{1}{nm}\sum_{x=1}^n \sum_{y=1}^m \sum_{i=0}^k {k\choose i} a_x^i b_y^{k-i}\\ &=\frac{1}{nm} \sum_{i=0}^k \sum_{x=1}^n \sum_{y=1}^m {k\choose i} a_x^i b_y^{k-i}\\ &=\frac{k!}{nm} \sum_{i=0}^k \sum \frac{a^i}{i!} \sum \frac{b^{k-i}}{(k-i)!} \end{aligned} \]

下面考虑如何对所有\(k\)求出\(\sum_{j=1}^n a_j^i\)
写出\(OGF\)后变换枚举顺序。

\[\begin{aligned} A&=\sum_{i=0}^\infty x^i \sum_{j=1}^n a_j^i\\ &=\sum_{i=1}^n \sum_{j=0}^\infty a_i^j x^j\\ &=\sum_{i=1}^n \frac{1}{1-a_ix} \end{aligned} \]

其实这里就可以分治然后通分了,但是常数比较大。
如果对函数嵌套起来求导的那个玩意比较熟悉的话可以想到\(ln(1-ax)'=\frac{-a}{1-ax}\)

\[\begin{aligned} A&=\sum \frac{1}{1-ax}\\ &=\sum 1-x\frac{-a}{1-ax}\\ &=n-x\sum ln(1-ax)'\\ &=n-x*ln(\prod 1-ax)' \end{aligned} \]

分治求出那个积之后带回去求可以求出\(A,B\),直接卷积即可。

posted @ 2019-12-22 21:57  _lhyyy  阅读(156)  评论(0编辑  收藏  举报