可重组合与不相邻组合

可重组合:

①A = {1, 2, 3, 4},从集合A中选出5个元素,可以重复,问有多少种不同的组合,例如{1, 2, 2, 3, 4}就算做一种

②有r个完全相同的小球,n个不同的盒子,每个盒子可以放任意数量的球,也可以不放,问有多少种方案

③线性方程x1+x2+…+xn=r的非负整数解的个数

①答案为C(8, 5),②③答案为C(n+r-1, r)

即在n个不同元素里取r个进行组合,允许重复的组合数为C(n+r-1, r)


不相邻组合:

从A = {1, 2, …, n}中取m个不相邻的数进行组合,情况个数为C(n-m+1, m)


对于当前序列,求出下一个的排列:

字典序法:例如数字839647521

①从右往左找到一个下降的数字,例子中为4

②找后缀中比4大的最小的数,并和4交换:839647521 → 839657421

③翻转后缀,完成:839657421 → 839651247


在由m个0,n个1组成的字符串中,出现01或10的总次数为k的字符串,有多少个?("010"中出现01or10总次数为2)

答案:

证明:当k为偶数时

①我们先假设两端一定是0,那么可以将所有的0排成一排:0-0-0-…-0-0,中间的-代表空隙。选择中间的k/2个位子放上1,就会生成刚好k个01or10,情况数C(m-1, k/2),还剩下n-k/2个1,刚好就是n-k/2个球放在k/2个不同盒子里,根据可重组合公式,情况个数为C(n-1,k/2-1),总情况为C(n-1, k/2-1)*C(m-1,k/2)

②当然还有可能两端都是1,那么可已将所有的1排成一排:1-1-1-…-1-1,你会发现计算方法和上面完全一样,所以总情况数为对称的(m-1, k/2-1)*C(n-1,k/2)

③那有没有可能一端是0一端是1呢?是不可能的,因为这个时候两端只会有一端对答案贡献1,而中间的贡献一定为偶数

综上,k为偶数时情况数为C(n-1, k/2-1)*C(m-1,k/2)+C(m-1, k/2-1)*C(n-1,k/2)得证

k为奇数时略(提示:情况和上面正好相反,①②情况数为0……)


你可能感兴趣的:(#,数论)