组合数学——排列组合经典模型

本文探讨了组合数学中的经典排列组合模型,包括不同条件下的球盒问题及划分模型,提供了详细的解决方案与公式。

组合数学——排列组合经典模型

球盒模型

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=0m1{min}

定义为Bell数。

nnn个不同的球放入mmm个不同的盒子里面,盒子允许为空

配对问题,答案为:

mn m^n mn

nnn个相同的球放入mmm个不同的盒子里面,盒子不允许为空

经典的隔板法,答案为:

(n−1m−1) \binom{n-1}{m-1} (m1n1)

nnn个相同的球放入mmm个不同的盒子里面,盒子允许为空

我们先放入m个相同的球,现在球的数量为n+mn+mn+m个,我们将这n+mn+mn+m个球放入mmm个不同的盒子里面,盒子不允许为空,最后再在每个盒子中抽走一个球,答案为:

(n+m−1m−1) \binom{n + m -1}{m-1} (m1n+m1)

或者,每一种情况对应一种仅由"N"和"P"组成的操作序列。我们一开始站在第一个盒子处,遇到"P"则在当前盒子放进一个球,遇到"N"则向右走一个箱子。这个序列由m−1m-1m1个"N"和nnn个"P"组成。

nnn个相同的球放入mmm个相同的盒子里面,盒子允许为空

我们考虑递归,当m>nm > nm>n的时候,必然会有m−nm-nmn个盒子为空,所以将其舍弃,为p(n,n)p(n,n)p(n,n)。其他情况,考虑划分成两种情况,第一种mmm个盒子全部非空,那么现将mmm个箱子每一个都放进一个球,方案数为p(n−m,m)p(n-m,m)p(nm,m)。第二种有至少一个盒子是空的,那么方案数为p(n,m−1)p(n,m-1)p(n,m1)

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(nm,m)

nnn个相同的球放入mmm个不同的盒子里面,每个盒子里面最多有一个小球,并且非空的盒子不能相邻

考虑现将小球放入盒子中,之后再每个盒子中插入一个空盒子,还剩下m−n+1m-n+1mn+1个盒子,考虑将这m−n+1m-n+1mn+1个盒子,可以用空放入n+1n+1n+1个位置。答案为(n−m+1n−2m+1)\binom{n-m+1}{n-2m+1}(n2m+1nm+1)

划分模型

划分模型指nnn个不同的元素,按照[n1,n2,…,nk][n_1,n_2,\ldots,n_k][n1,n2,,nk]进行划分成kkk组,其中∑ni=n\sum{n_i} = nni=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=siSsi!i=1k(nknj=1k1ni)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值