错排

定义

错排,也就是全错的排列,即长度为 \(n\) 的排列满足 \(\forall i,a_i\ne i\) 的方案数。
一般采用 \(d_n\) 表示错排。

递推

\(n\) 个元素不能放在下标为 \(n\) 的格子里,所以假设放在下标为 \(p(p\ne n)\) 的格子。
\(p\) 个元素如果放在下标为 \(n\) 的格子里,其他元素的方案数就是 \(d_{n-2}\)
\(p\) 个元素如果不放在下标为 \(n\) 的格子里,那么建立一个对应关系。发现 \(1\sim n-1\) 这些元素都有且仅有一个位置不能放,这就是一个错排,方案数就是 \(d_{n-1}\)
由于 \(p\)\(n-1\) 种取值,所以,\(d_n=(n-1)(d_{n-1}+d_{n-2})\)

通项

采用容斥原理,钦定 \(k\) 个元素强行放在原本的位置上。

\[d_n=\sum_{k=0}^n(-1)^k\binom nk(n-k)! \]

这个式子也可以用二项式反演获得。

\[n!=\sum_{k=0}^n\binom nkd_k \]

但是这个式子带 \(\sum\),不优雅。

\[\begin{aligned} d_n&=\sum_{k=0}^n(-1)^k\binom nk(n-k)!\\ &=\sum_{k=0}^n(-1)^k\frac{n!(n-k)!}{k!(n-k)!}\\ &=n!\sum_{k=0}^n\frac{(-1)^k}{k!}\\ \end{aligned} \]

\(e^{-1}\) 泰勒展开。

\[e^{-1}=\sum_{k=0}^\infty\frac{(-1)^k}{k!} \]

那么 \(e^{-1}n!-d_n\) 就可以计算了。

\[\begin{aligned} &e^{-1}n!-d_n\\ &=n!(\sum_{k=0}^\infty\frac{(-1)^k}{k!}-\sum_{k=0}^n\frac{(-1)^k}{k!})\\ &=n!\sum_{k=n+1}^\infty\frac{(-1)^k}{k!}\\ &=n!\sum_{k=0}^\infty\frac{(-1)^{n+k+1}}{(n+k+1)!}\\ &=(-1)^{n+1}n!\sum_{k=0}^\infty\frac{(-1)^k}{(n+k+1)!}\\ &=(-1)^{n+1}\sum_{k=0}^\infty(-1)^k\frac{n!}{(n+k+1)!}\\ \end{aligned} \]

对于 \(i\) 为奇数,有:

\[0<\frac{n!}{(n+i)!}-\frac{n!}{(n+i+1)!}<\frac{n!}{(n+i)!}<\frac1{n^i} \]

\[0<\sum_{k=0}^\infty(-1)^k\frac{n!}{(n+k+1)!}<\sum_{i=0}^\infty\frac1{n^{2i+1}}=\frac n{n^2-1} \]

所以把这个式子带入

\[\begin{aligned} 0<\sum_{k=0}^\infty(-1)^k\frac{n!}{(n+k+1)!}<\frac n{n^2-1}\\ 0<|(-1)^{n+1}\sum_{k=0}^\infty(-1)^k\frac{n!}{(n+k+1)!}|<(-1)^{n+1}\frac n{n^2-1}\\ 0<|e^{-1}n!-d_n|<\frac n{n^2-1}\\ \end{aligned} \]

\(n\ge3\) 时,\(\frac n{n^2-1}<\frac12\) 成立,所以 \(0<|e^{-1}n!-d_n|<\frac12\)
\(n=1\)\(n=2\) 时,\(0<|e^{-1}n!-d_n|<\frac12\) 经计算,也成立。
所以 \(d_n\) 就是 \(e^{-1}n!\) 四舍五入,也就是 \(\lfloor e^{-1}n!+\frac12\rfloor\)
由此,\(\lim\limits_{n\to\infty}\frac{d_n}n=\frac1e\)

posted @ 2024-02-04 17:57  蒟酱  阅读(40)  评论(0编辑  收藏  举报