博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
排列与组合的一些定理(二)
阅读量:6303 次
发布时间:2019-06-22

本文共 3367 字,大约阅读时间需要 11 分钟。

一,容斥原理

设S是一个集合,Ai 是S 中具有性质 Pi 的元素组成的子集合。那么,S中既不具有性质P1,也不具有性质P2,...更不具有性质Pn 的元素个数为:

 

二,容斥原理计算 有限制的重组合问题

①什么是有限制的重组合问题?(重组合就是,某个元素可重复选择)

集合{k1·b1,k2·b2,....,kn·bn}中选取r个元素,(不考虑次序),一共有多少种组合?

元素,可以是一个抽象的概念。一切问题,只要满足这个“范式”,就可以视为一个重组合问题,从而用容斥原理求解。

从集合可以看出:b1最多只能选取k1,b2最多只能选取k2,...,bn 最多只能选取kn

而在的末尾提到了无限的重组合问题求解公式。因此,可以试着将有限制的重组合问题转化为无限制的重组合问题(但是附加了一些条件)

解法如下:

首先考虑问题1:在无限制的重组合问题的 集合中选取 r 个元素时,一共有多少种选取方法?----答案是一共有F(n,r)种。

然后再定义: 性质A1 表示 问题1得到的选取方案中 至少要存在 k1+1 个b1

性质A2 表示 问题1得到的选取方案中 至少要存在 k2+1 个b2

.....

性质An 表示 问题1得到的选取方案中 至少要存在 kn+1 个bn

从而,问题:从集合{k1·b1,k2·b2,....,kn·bn}中选取r个元素,(不考虑次序),一共有多少种组合?

转化成了:从集合{∞·b1∞·b2,....,∞·bn}中选取r个元素,(不考虑次序),并且b1不超过k1 b2不超过k2,bn不超过kn,一共有多少种组合?

因此,有限制的重组合问题就转化成了无限制的重组合问题,但是附加了条件:b1不超过k1 ,b2不超过k2,bn不超过kn

用数学公式表示就是:|A¯1 A¯2∩....A¯n|    A¯1表示不具有A1性质的集合(即A1的非)

根据容斥原理:|A¯1 A¯2∩....A¯n|就可以计算出来了。

 

三,容斥原理计算错排问题

错排问题就是:给定N个数1,2,3...n  要求第 i 个数不在 第 i 个位置上,一共有多少种排列?

性质A1表示第 1 个数恰好在 1 位置上

性质A2表示第 2 个数恰好在 2 位置上

.....

性质An表示第 n 个数恰好在 n 位置上

错排问题就可以表示成公式:|A¯1 A¯2∩....A¯n| ,就可以用“容斥原理”来计算了。

 

四,棋盘多项式

是一种更复杂度的错排问题。

比如,给定一个4行4列的矩阵,元素1不能放在第1行第2列;元素2不能放在第4行第3列;元素3不能放在第1行第3列。求这三个元素一共有多少种放置方式?

 

五,母函数

母函数有两种:普通的母函数 和 指数母函数。普通母函数一般用来解决组合问题,指数母函数用来解决排列问题。

不管是排列问题,还是组合问题。都是从 n 个数中选出若干个数。排列问题关注的是:是把选出的数做排列(考虑顺序),组合问题则是不考虑顺序。

①普通母函数

(1+x)(1+x)...(1+x)(1+x)=(1+x)n 这个公式表示了:一共有n个物品,每个物品要么不选,要么选中(每个物品最多只能选一次)。

对于每一项(1+x),1 表示不选,x表示选中。一共有 n 个(1+x),即表示一共有 n 个物品。

那么从 n 个物品中选取 r个一共有多少种选择?(不考虑顺序--默认是组合问题)

(1+x)(1+x)...(1+x)(1+x) 乘出来,得到1,2...n的多项式。xr 的系数就是: n 个物品中选取 r个的 总共的选取方法数。

由二项式定理:(1+x)n = C(n,0)X0 Yn + C(n,1)X1 Yn-1 +.....+ C(n,n)Xn Y0 = C(n,0)X0 + C(n,1)X1 +.....+ C(n,n)Xn(其中Y=1)

可以看出 xr 的系数为C(n,r),刚好符合。

普通,对这种简单的组合问题,用普通母函数计算太复杂了。普通母函数合适的是更复杂一些的组合问题

如,有 n 个物品,每个物品最多可选两次,从中选取 r 个有多少种选择方案?母函数为:

(1+x+x2)(1+x+x2).....(1+x+x2) = (1+x+x2)n

选择方案数为(1+x+x2)(1+x+x2).....(1+x+x2) = (1+x+x2)n xr 的系数。

再比如,有 n 个物品,每个只能选奇数次,母函数如下:

(x+x3+...x2k-1)(x+x3+...x2k-1).....(x+x3+...x2k-1) = (x+x3+...x2k-1)n

......

再比如,有4 个物品,第1个物品最多只能选 2次,第二个物品只能选奇数次,第三个物品只能选偶数次,第四个物品最多只能选取3次。从中选取 r 个物品,一共有多少种选择方案?(组合问题)

普通母函数如下:(1+x+x2)(x+x3+...x2k-1)(1+x2+...x2k)(1+x+x2+x3)

将上面的母函数解出来,xr 的系数就是选择的方案的数目。

 

②指数母函数

指数母函数的用法与普通母函数的用法一致。只不过是“表示形式”不同而已。

(1+x+x2+x3)在普通母函数中 表示某个物品在组合计数中 可选0次,1次,2次,3次【或者说该物品最多可选3次】

指数母函数中选择某个物品该如何表示呢?

(1+x+x2/2!+x3/3!+...+xk/k!)就表示:某个物品在排列计数中 可选0次,1次,2次....k次【或者说该物品最多可选k次】

如,有 n 个物品,每个物品最多可选两次,从中选取 r 个有多少种选择方案?母函数为:

(1+x+x2/2!)(1+x+x2/2!).....(1+x+x2/2!) = (1+x+x2/2!)n

选择方案数为(1+x+x2/2!)(1+x+x2/2!).....(1+x+x2/2!) = (1+x+x2/2!)nxr 的系数。

再比如,有4 个物品,第1个物品最多只能选 2次,第二个物品只能选奇数次,第三个物品只能选偶数次,第四个物品最多只能选取3次。从中选取 r 个物品,一共有多少种选择方案?(排列问题)

指数母函数如下:(1+x+x2/2!)[(x+x3/3!+...x2k-1/(2k-1)!)][(1+x2/2!+...x2k/(2k)!](1+x+x2/2!+x3/3!)

排列的方案数就是指数母函数解出来,xr的系数

 

六,整数拆分

给定一个整数 n,将 n 拆分成 1,2,3 的和,一共有多少种拆分方式?

比如:n=4。 4=1+1+1+1;4=1+1+2;4=2+2;4=1+3

故一共有4种拆分方式。

考虑(1-x)-1 = (1+x+x2+...+xn),根据上面的普通母函数可知:“某个物品可选0次,1次,2次.....n次” (1*[0,1,2,...n])

比如:x3 就表示数字1选取了3次,x2表示数字1选取了2次....

考虑(1-x2)-1 = (1+x2+x4+...+x2n),根据上面的普通母函数可知:“某个物品可选0次,2次,4次.....2n次” (2*[0,1,2,...n])

比如:x6就表示数字2选取了3次,x4表示数字2选取了2次....

考虑(1-x3)-1 = (1+x2+x4+...+x2n),根据上面的普通母函数可知:“某个物品可选0次,3次,6次.....3n次”(3*[0,1,2,...n])

比如:x6就表示数字3选取了2次,x3表示数字3选取了1次....

 

因此,整数 n 拆分成1,2,3之和的方式数为:

(1-x1)-1 *(1-x2)-1 * (1-x3)-1 xn 的系数就是整数 n 拆分成 1,2,3 之和的方式数。(也就是说 n 只能由 1,2,3 相加得到,但是1,2,3,可以出现多次)

定理:给定一个整数 n ,将 n 拆分成 a ,b ,c ...和的方法数是:

 

七,一些常用的泰勒展开式

(1-x)-1 = 1+x2+x3+....+xn+...

ex=1+x+x2/2!+x3/3!+...+xn/n!+....

 

八,参考资料

转载地址:http://ovfxa.baihongyu.com/

你可能感兴趣的文章
Android中Handler引起的内存泄露
查看>>
原产地政策,jsonp跨域
查看>>
HDU 1143 Tri Tiling(递归)
查看>>
ffmpeg参数具体解释
查看>>
记一次公司仓库数据库服务器死锁过程
查看>>
Oracle 11g password过期被锁定报道 ORA-28000 the account is locked
查看>>
【Struts2学习笔记(2)】Action默认值和配置Action于result各种转发类型
查看>>
轨磁条简介
查看>>
(算法)交错的字符串
查看>>
hdu 5471(状压DP or 容斥)
查看>>
oracle.jdbc.driver.OracleDriver和oracle.jdbc.OracleDriver这两个驱动的区别
查看>>
NSQ部署
查看>>
git常用命令记录
查看>>
IBM发布新一代云计算工具包MobileFirst Foundation
查看>>
唯品会HDFS性能挑战和优化实践
查看>>
大规模学习该如何权衡得失?解读NeurIPS 2018时间检验奖获奖论文
查看>>
大厂前端高频面试问题与答案精选
查看>>
我们用5分钟写了一个跨多端项目
查看>>
Visual Studio 15.4发布,新增多平台支持
查看>>
有赞透明多级缓存解决方案(TMC)设计思路
查看>>