组合数学——排列组合经典模型
球盒模型
nnn个不同的球放入mmm个相同的盒子里面,盒子不允许为空
这和第二类斯特林数的定义相同,答案为{nm}{n \brace m}{mn}。
nnn个不同的球放入mmm个不同的盒子里面,盒子不允许为空
通过第二类斯特林数计算出nnn个不同的球放入mmm个相同的盒子里面,盒子不允许为空的方案数为{nm}{n \brace m}{mn},之后再对mmm个盒子进行排列即可,答案为{nm}×m!{n \brace m} \times m!{mn}×m!。
nnn个不同的球放入mmm个相同的盒子里面,盒子允许为空
枚举空盒数量即可,答案为:
∑i=0m−1{nm−i} \sum_{i=0}^{m-1}{n \brace m-i} i=0∑m−1{m−in}
定义为Bell数。
nnn个不同的球放入mmm个不同的盒子里面,盒子允许为空
配对问题,答案为:
mn m^n mn
nnn个相同的球放入mmm个不同的盒子里面,盒子不允许为空
经典的隔板法,答案为:
(n−1m−1) \binom{n-1}{m-1} (m−1n−1)
nnn个相同的球放入mmm个不同的盒子里面,盒子允许为空
我们先放入m个相同的球,现在球的数量为n+mn+mn+m个,我们将这n+mn+mn+m个球放入mmm个不同的盒子里面,盒子不允许为空,最后再在每个盒子中抽走一个球,答案为:
(n+m−1m−1) \binom{n + m -1}{m-1} (m−1n+m−1)
或者,每一种情况对应一种仅由"N"和"P"组成的操作序列。我们一开始站在第一个盒子处,遇到"P"则在当前盒子放进一个球,遇到"N"则向右走一个箱子。这个序列由m−1m-1m−1个"N"和nnn个"P"组成。
nnn个相同的球放入mmm个相同的盒子里面,盒子允许为空
我们考虑递归,当m>nm > nm>n的时候,必然会有m−nm-nm−n个盒子为空,所以将其舍弃,为p(n,n)p(n,n)p(n,n)。其他情况,考虑划分成两种情况,第一种mmm个盒子全部非空,那么现将mmm个箱子每一个都放进一个球,方案数为p(n−m,m)p(n-m,m)p(n−m,m)。第二种有至少一个盒子是空的,那么方案数为p(n,m−1)p(n,m-1)p(n,m−1)。
int partition(int n, int m)
{
if (n == 0)
return 1;
if (m == 0)
return 0;
if (m > n)
return partition(n, n);
else
return partition(n, m - 1) + partition(n - m, m);
}
nnn个相同的球放入mmm个相同的盒子里面,盒子不允许为空
先将mmm个盒子每一个放入一个小球,保证非空,然后转为为上一个问题,答案为p(n−m,m)p(n-m,m)p(n−m,m)
nnn个相同的球放入mmm个不同的盒子里面,每个盒子里面最多有一个小球,并且非空的盒子不能相邻
考虑现将小球放入盒子中,之后再每个盒子中插入一个空盒子,还剩下m−n+1m-n+1m−n+1个盒子,考虑将这m−n+1m-n+1m−n+1个盒子,可以用空放入n+1n+1n+1个位置。答案为(n−m+1n−2m+1)\binom{n-m+1}{n-2m+1}(n−2m+1n−m+1)
划分模型
划分模型指nnn个不同的元素,按照[n1,n2,…,nk][n_1,n_2,\ldots,n_k][n1,n2,…,nk]进行划分成kkk组,其中∑ni=n\sum{n_i} = n∑ni=n,问有多少种划分方式。
我们先按照nin_ini的大小相同的分到一个集合中,那么SSS集合就是多值集合[n1,n2,…,nk][n_1,n_2,\ldots,n_k][n1,n2,…,nk]的一个划分。
那么答案为:
ans=∏i=1k(n−∑j=1k−1nink)∏si∈S∣si∣! \text{ans} = \frac{\prod_{i = 1}^k \binom{n - \sum_{j = 1}^{k - 1}n_i}{n_k}}{ \prod_{s_i \in S} |s_i|!} ans=∏si∈S∣si∣!∏i=1k(nkn−∑j=1k−1ni)
本文探讨了组合数学中的经典排列组合模型,包括不同条件下的球盒问题及划分模型,提供了详细的解决方案与公式。
4056

被折叠的 条评论
为什么被折叠?



