需要注意题目求解的是操作 nn 次出现 xx 次王牌,而不是第一次出现王牌是第 xx 次。

p=1mp=\dfrac{1}{m} 也就选出王牌的概率,q=1pq=1-p

那么如果直接枚举出现王牌的数量,有式子:

i=0n(ni)piqniik\sum\limits_{i=0}^n {n\choose i}p^iq^{n-i}i^k

根据套路把 iki^k 展开为第二类斯特林数:

i=0n(ni)piqniik=i=0n(ni)piqnij=1k{kj}i!(ij)!\sum\limits_{i=0}^n {n\choose i}p^iq^{n-i}i^k=\sum\limits_{i=0}^n{n\choose i}p^iq^{n-i}\sum_{j=1}^k\begin{Bmatrix}k\\ j\end{Bmatrix}\dfrac{i!}{(i-j)!}

因为我们希望最后的时间复杂度与 nn 无关,先把与 nn 有关的式子移动到外面:

i=0n(ni)piqniik=j=1k{kj}i=0n(ni)piqnii!(ij)!\sum\limits_{i=0}^n {n\choose i}p^iq^{n-i}i^k=\sum\limits_{j=1}^k\begin{Bmatrix}k\\ j\end{Bmatrix}\sum\limits_{i=0}^n {n\choose i}p^iq^{n-i}\dfrac{i!}{(i-j)!}

考虑把后面的一坨式子化简,阶乘一般的处理手段都是加入组合数然后根据组合数的性质快速计算。

i=0n(ni)piqnii!(ij)!=i=0nn!i!(ni)!×i!(ij)!piqni\sum\limits_{i=0}^n {n\choose i}p^iq^{n-i}\dfrac{i!}{(i-j)!}=\sum\limits_{i=0}^n \dfrac{n!}{i!(n-i)!}\times \dfrac{i!}{(i-j)!}p^iq^{n-i}

因为阶乘很狗屎,所以先处理阶乘。

i=0n(niij)n!(nj)!piqni\sum\limits_{i=0}^n {n-i\choose i-j}\dfrac{n!}{(n-j)!}p^iq^{n-i}

把式子分开看:

n!(nj)!i=0nj(nii)pi+j(1p)nij\dfrac{n!}{(n-j)!}\sum\limits_{i=0}^{n-j} {n-i\choose i}p^{i+j}(1-p)^{n-i-j}

这里需要补一下二项式定理:

(a+b)n=i=0n(ni)aibni(a+b)^n=\sum\limits_{i=0}^n {n\choose i}a^{i}b^{n-i}

发现跟上面的式子有点像,考虑把 pip^i 提出来,得到:

n!(nj)!pj(p+(1p))ni=n!(nj)!×pj\dfrac{n!}{(n-j)!}p^j(p+(1-p))^{n-i}=\dfrac{n!}{(n-j)!}\times p^j

将化简之后的结果带回原式,得到:

j=0k{kj}n!(nj)!pj\sum\limits_{j=0}^k \begin{Bmatrix}k\\ j\end{Bmatrix}\dfrac{n!}{(n-j)!}p^j

虽然是垃圾的 O(klogn)O(k\log n),但是你就说能不能过吧。