首页 > 其他分享 >斯特林数

斯特林数

时间:2022-11-05 12:02:19浏览次数:67  
标签:begin end Bmatrix 斯特林 轮换 bmatrix

source:《具体数学》第六章
记号:
\(\begin{Bmatrix}n\\k\end{Bmatrix}\):第二类斯特林数,读作“\(n\) 子集 \(k\)”。
\(\begin{bmatrix}n\\k\end{bmatrix}\):第一类斯特林数,读作“\(n\) 轮换 \(k\)”。

基本思想:
一一对应;递推。


第二类斯特林数

\(n\) 个元素划分成 \(k\) 个无标号的集合,有几种方案?
如 \(\begin{Bmatrix}4\\2\end{Bmatrix} = 7\),因为有:

\[\{1\},\{2,3,4\} \\ \{2\},\{1,3,4\} \\ \{3\},\{1,2,4\} \\ \{1,2\},\{3,4\} \\ \{1,3\},\{2,4\} \\ \{2,3\},\{1,4\} \\ \{1,2,3\},\{4\} \\ \]

大括号表示子集符号,这一符号雷同也颇具含义。

显然有初始状态 \(\begin{Bmatrix}n\\n\end{Bmatrix} = 1, \begin{Bmatrix}k\\0\end{Bmatrix} = 0(k>0)\)。

考虑递推。
考虑最后一个数字加入什么集合。
可以新开一个集合,也可以选择之前的集合加入。
那么

\[\begin{Bmatrix}n\\k\end{Bmatrix} = \begin{Bmatrix}n-1\\k-1\end{Bmatrix} + k\begin{Bmatrix}n-1\\k\end{Bmatrix}\]

时间复杂度 \(O(nk)\)。

有标号?乘以 \(k!\) 即可。

https://codeforces.com/gym/100342/problem/D

第一类斯特林数

\(n\) 个元素划分成 \(k\) 个无标号的轮换,有几种方案?

注意轮换指的是若干个数字组成的一个环。比如 \([1,2,3,4] = [3,4,1,2]\),但是 \([1,2,3,4] \neq [4,3,2,1]\)。

如 \(\begin{bmatrix}4\\2\end{bmatrix} = 11\),因为有:

\[[1,2,3],[4] \\ [1,3,2],[4] \\ (剩下六组轮换) \\ [1,2],[3,4] \\ [1,3],[2,4] \\ [2,3],[1,4] \\ \]

我们先来探讨特殊情况。

两个数的集合可以组成几个轮换?一个,因为 \([A,B]=[B,A]\)。三个数的集合可以组成两个轮换:\([A,B,C],[A,C,B]\)。

\(n\) 个数的集合 \(\{1,...,n\}\) 可以组成几个轮换?考虑钦定 \(1\) 放在最前面,那么剩下 \(n-1\) 个数的排列与 \(n\) 个数的轮换一一对应,也就是 \(\begin{bmatrix}n\\1\end{bmatrix} = (n-1)!\)。

注意到 \(\begin{bmatrix}n\\k\end{bmatrix} \geq \begin{Bmatrix}n\\k\end{Bmatrix}\) 恒成立。因为一个子集可以有若干个轮换。

考虑递推。最后一个数怎么插?可以单独成为一个轮换。不单独成为轮换的情况有几种呢?考虑钦定所有轮换的第一个数,那么每一个数之前都可以插入最后一个数形成一个新的轮换:

\[[A,B,C,D] + E \\ \rightarrow \\ [E,A,B,C,D] \\ [A,E,B,C,D] \\ [A,B,E,C,D] \\ [A,B,C,E,D] \\ \]

注意,\([A,B,C,D,E] = [E,A,B,C,D]\),因此末尾不能够插入数。这样,一共有 \(n-1\) 个位置可以插入数。

因此有

\[\begin{bmatrix}n\\k\end{bmatrix} = \begin{bmatrix}n-1\\k-1\end{bmatrix} + (n-1)\begin{bmatrix}n-1\\k\end{bmatrix}\]

时间复杂度 \(O(nk)\)。

标签:begin,end,Bmatrix,斯特林,轮换,bmatrix
From: https://www.cnblogs.com/Zeardoe/p/16859913.html

相关文章

  • 【POJ1430】Binary Stirling Numbers(第二类斯特林数,组合数)
    求\(\begin{Bmatrix}n\\m\end{Bmatrix}\bmod2\)的值。由第二类斯特林数的递推公式:\[\begin{Bmatrix}n\\m\end{Bmatrix}=\begin{Bmatrix}n-1\\m-1\end{Bmatrix}+m\begi......
  • 【51NOD1847】奇怪的数学题(杜教筛,min_25筛,第二类斯特林数解决自然数幂求和)
    设\(f(n)\)表示\(n\)的次大因数。\[\begin{aligned}&\sum_{i=1}^n\sum_{j=1}^nf(\gcd(i,j))^k\\=&\sum_{d=1}^nf(d)^k\sum_{i=1}^{(n/d)}\sum_{j=1}^{(n/d)}[\gcd(i......
  • 自然数幂和(第二类斯特林数)
    引言然而并没有什么内容之所以是第二类斯特林数的原因是今天比赛写的拉插被卡了。。。第xxx次被卡常第二类\(\text{Stirling}\)数将\(n\)个两两不同的元素划分为......
  • 斯特林数与贝尔数求法
    现在在码两篇博客,一篇lin4xu杂题全题解,一篇博弈论。然后我现在一个都没码完又开一个斯特林数。我们先不管斯特林数有什么性质,这个以后专门开个数数专题。直接开始看怎么求......
  • 【斯特林数总结】
    第二类斯特林数组合意义:将n个有标号物品划分为m个无标号的非空集合的方案数,记为\(n\bracem\)递推式\[\begin{aligned}{0\brace0}&=1\\{n\brace0}&=0\quad(n>0......
  • 斯特林数的四种求法
    有一回对我说道,“你读过书么?”我略略点一点头。他说,“读过书,……我便考你一考。组合数学里的斯特林数,怎样说的?”我想,AKIOI的人,我也配答么?便回过脸去,不再理会。田乙己等了许......
  • 斯特林数
    斯特林数一共分为两类,较第一类来说,第二类斯特林数更加常用,接下来分别介绍他们。第一类斯特林数:定义:用\(s(n,m)\)表示第一类斯特林数,其含义是把\(n\)个数分成\(m\)......