[SinGuLaRiTy] 组合数学
【SinGuLaRiTy-1005】 Copyright (c) SinGuLaRiTy 2017. All Rights Reserved .
加法原理
设事件A有m种产生方式,事件B有n种产生方式,则事件A或B之一有m+n种产生方式。
集合论语言:若 |A| = m , |B| = n , A∩B = Φ, 则 |AUB| = m + n 。
<例>
(1)某班选修企业管理的有 18 人,不选的有 10 人,则该班共有 18 + 10 = 28 人。
(2)北京每天直达上海的客车有 5 次,客机有 3 次, 则每天由北京直达上海的旅行方式有 5 + 3 = 8 种。
乘法原理
设事件A有m种产生式,事件B有n种产生方式,则事件A与B有 m · n种产生方式。
集合论语言:若 |A| = m , |B| = n , A*B = {(a,b) | a∈A,b ∈ B}, 则 |A * B| = m * n 。
<例>
(1) 某种字符串由两个字符组成,第一个字符可选自{a,b,c,d,e},第二个字符可选自{1,2,3},则这种字符串共有5 * 3 = 15 个。
(2) 从A到B有三条道路,从B到C有两条道路,则从A经B到C有3 * 2=6 条道路。
(3*)a.求小于10000的含1的正整数的个数
分析:
小于10000的不含1的正整数可看做4位数,但0000除外.
故有9×9×9×9-1=6560个.
含1的有:9999-6560=3439个
b.求小于10000的含0的正整数的个数
分析:
不含0的1位数有9个,2位数有9*9 个,3位数有9^3 个,4位数有9^4 个
不含0小于10000的正整数有9+9^2+9^3+9^4 =7380个
含0小于10000的正整数有9999-7380=2619个
排列与组合
定义:从n个不同的元素中,取r个不重复的元素,按次序排列,称为从n个中取r个的无重排列。当r=n时称为全排列。一般不说可重即无重。可重排列的相应记号为 P(n,r) 。
排列:从n个中取r个的排列的典型例子是从n个不同的球中,取出r个,放入r个不同的盒子里,每盒1个。第1个盒子有n种选择,第2个有n-1种选择,······,第r个有n-r+1种选择。故有P(n,r)=n(n-1)······(n-r+1)。
组合:从n个中取r个的组合的典型例子是从n个不同的球中,取出r个,放入r个相同的盒子里。每个盒子要放一个球。每一种组合方案都可以衍生出r!种排列方案来。C(n,r)=p(n,r)/r! 。
<组合公式的性质>
性质1:C(n,0)=C(n,n)
性质2:C(n,k)=C(n,n-k)
性质3:C(n,k)+C(n,k+1)=C(n+1,k+1)
二项式定理:
<例>
1.有重复元素的全排列
有k种元素,其中第i种元素有ni个,所有元素一共是n个。求全排列的个数.
解:设元素的总数为n。它同一类元素被重复计算了ni!次.所以答案为:n!/(n1!*n2!*…nk!)
2.可重复选择的组合
有n个不同的元素,每个元素可以选多次,一共选择k个元素,有多少种方法?
如n=3,k=2,有6种选择:(1,1),(1,2),(1,3),(2,2),(2,3),(3,3)
分析:设第一个元素选择x1个,第二个元素选择x2个,……,第n个元素选择xn个。则有方程:x1+x2+……xn=k。问题转换为求方程的非负整数解的个数。令yi=xi+1,则答案为y1+y2+…+yn=k+n的正整数解的个数。想想k+n个相同的小球拍成1列,现在要把它分成n个部分,则只需在其中放置n-1块隔板即可。一共有k+n-1个位置用来放隔板,所以答案为C(n+k-1,n-1)
集合拆分
<整数的无序拆分>
将一个整数n拆成无序的k个数的和,问有多少种方法?
将n个相同的球全部放入k个相同的盒子,问有多少种方法?
p(n,k)=p(n-1,k-1)+p(n-k,k)
<集合的无序分拆(第二类stirling)>
将一个包含n个元素的集合拆成k个子集,每个子集非空,且子集之间无交集,问有多少种方法?
设S(n,k)表示解,则S(n,k)=S(n-1,k-1)+S(n-1,k)*k,其中S(n,n)=1,S(n,1)=1,若i<j,则S(i,j)=0.
将n个不同的小球全部放入k个相同的盒子,要求每个盒子都不为空。
<集合的有序分拆>
将一个包含n个元素的集合拆成有序的k个子集,每个子集非空,且子集之间无交集,问有多少种方法?
将n个不同的小球全部放入k个不同的盒子,要求每个盒子都不为空。
设S(n,k)表示集合n的无序分拆,则本题的答案为:
k!*S(n,k)
其中S(n,n)=1,S(n,1)=1,若i<j,则S(i,j)=0
<整数的有序拆分>
将一个整数n拆成有序的k个数的和,问有多少种方法?
将n个相同的球全部放入k个不同的盒子,问有多少种方法?
C(n-1,k-1)
<*经典分配问题12态>
第一类Stirling数
将n个不同的数分成k个非空循环排列一共有多少种方法。
S1(n,k)=S1(n-1,k-1)+(n-1)*S1(n-1,k)
递推关系的说明:
考虑第n个数,n可以单独构成一个非空循环排列,这样前n-1种数构成k-1个非空循环排列,方法数为s1(n-1,k-1);
也可以前n-1种数构成k个非空循环排列,而第n个数插入第i个数的左边,这有(n-1)*s1(n-1,k)种方法。
鸽笼原理
又名抽屉原理。有n个鸽笼,现在放入m只鸽子(m>n)则必有两只鸽子在一个笼子。
容斥原理
如果被计数的事物有A、B、C三类,那么,A类和B类和C类元素个数总和= A类元素个数+ B类元素个数+C类元素个数—既是A类又是B类的元素个数—既是A类又是C类的元素个数—既是B类又是C类的元素个数+既是A类又是B类而且是C类的元素个数。
(A∪B∪C = A+B+C - A∩B - B∩C - C∩A + A∩B∩C)
<公式>
Time : 2017-02-08
[SinGuLaRiTy] 组合数学的更多相关文章
- [SinGuLaRiTy] 组合数学题目复习
[SinGuLaRiTy] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. [CQBZOJ 2011] 计算系数 题目描述 给定一个多项式( ...
- [SinGuLaRiTy] 2017 百度之星程序设计大赛 初赛B
[SinGuLaRiTy-1037] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. Chess Time Limit: 2000/1000 ...
- [SinGuLaRiTy] NOIP膜你赛-Day 1
[SinGuLRiTy-1022] Copyright (c) SinGuLaRITy 2017. All Rights Reserved. 对于所有题目:Time Limit:1s || Memo ...
- poj 3734 Blocks 快速幂+费马小定理+组合数学
题目链接 题意:有一排砖,可以染红蓝绿黄四种不同的颜色,要求红和绿两种颜色砖的个数都是偶数,问一共有多少种方案,结果对10007取余. 题解:刚看这道题第一感觉是组合数学,正向推了一会还没等推出来队友 ...
- 组合数学or not ---- n选k有重
模板问题: 1. 取物品 (comb.pas/c/cpp) [问题描述] 现在有n个物品(有可能相同),请您编程计算从中取k个有多少种不同的取法.[输入] 输入文件有两行,第一行包含两个整数n,k(2 ...
- 组合数学(全排列)+DFS CSU 1563 Lexicography
题目传送门 /* 题意:求第K个全排列 组合数学:首先,使用next_permutation 函数会超时,思路应该转变, 摘抄网上的解法如下: 假设第一位是a,不论a是什么数,axxxxxxxx一共有 ...
- uestc1888 Birthday Party 组合数学,乘法原理
题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=25539#problem/G 题目意思: 有n个人,每个人有一个礼物,每个人能拿 ...
- The Brain vs Deep Learning Part I: Computational Complexity — Or Why the Singularity Is Nowhere Near
The Brain vs Deep Learning Part I: Computational Complexity — Or Why the Singularity Is Nowhere Near ...
- UVA 11076 Add Again 计算对答案的贡献+组合数学
A pair of numbers has a unique LCM but a single number can be the LCM of more than one possiblepairs ...
随机推荐
- event.target的第一次
今天在学习其他人代码的时候见到了event.target.nodeName,event.target.dataset.刚开始是一头雾水,便google一下.发现大多数给出的词条都是有关jQuery事件 ...
- ACM 海贼王之伟大航路(深搜剪枝)
"我是要成为海贼王的男人!" 路飞他们伟大航路行程的起点是罗格镇,终点是拉夫德鲁(那里藏匿着"唯一的大秘宝"--ONE PIECE).而航程中间,则是各式各样的 ...
- Github创建分支
一.clone Repository clone Github 上的Repository,如下: git clone git@github.com:FBing/design-patterns.git ...
- 第35篇 IIS执行原理
服务器的监听(IIS6.0+版本) 当请求到达服务器时,请求最终会到达TCPIP.SYS驱动程序,TCPIP.SYS将请求转发给HTTP.SYS网络驱动程序的请求队列中(可以理解为专门处理http请求 ...
- APIJSON,让接口和文档见鬼去吧!
我: APIJSON,让接口和文档见鬼去吧! https://github.com/TommyLemon/APIJSON 服务端: 什么鬼? 客户端: APIJSON是啥? 我: APIJSON是一种 ...
- Yii地址美化(nginx环境)
通过urlmanager实现yii地址美化,需配合服务器中的rewrite配置 1.在'components'中加入 'urlManager'=>array( 'ur ...
- Servlet+Tomcat日志输出
刚接触Servlet的时候,为了学习方便总是想验证自己的想法,那么输出日志是最常见的手法了,就自己亲身经历总结了如下几种方法,我用的是Web容器是Tomcat. 使用Log4J 在<Servle ...
- vue组件最佳实践
看了老外的一篇关于组件开发的建议(强烈建议阅读英文原版),感觉不错翻译一下加深理解. 这篇文章制定一个统一的规则来开发你的vue程序,以至于达到一下目的. 1.让开发者和开发团队更容易发现一些事情. ...
- 【JS】JavaScript中的执行环境与作用域
JavaScript中的执行环境定义了变量或函数有权访问的数据(每个函数都有自己的执行环境),全局执行环境是最外围的执行环境,在浏览器中,全局执行环境就是window对象,所以所有的全局变量和函数都是 ...
- ajax 实现三级联动
ajax 实现三级联动,相当于写了一个小插件,用的时候直接拿过来用就可以了,这里我用了数据库中的chinastates表, 数据库内容很多,三级联动里的地区名称都在里面,采用的是代号副代号的方式 比如 ...