假设你的音乐库中有 10 首歌曲,你想要随机播放所有歌曲(即这 10 首歌曲会以随机顺序播放)。你的音乐库可以有多少种不同的播放方式?
这种类型的题被称为有序选择(排列),因为我们是在选取音乐库中的歌曲并以特定顺序进行播放。例如,以下这些选择被认为是不同的:
data:image/s3,"s3://crabby-images/86017/86017039a0cf974bb7bc93af1f3176d5687226e4" alt="{\displaystyle {\begin{array}{l}1,2,3,4,5,6,7,8,9,10\\7,3,10,4,9,5,1,8,2,6\\2,1,3,4,5,6,7,8,9,10\end{array}}}"
这些明显地定义了不同的播放顺序,或实际上,不同的播放列表。
让我们逐步思考。我们可以从 10 首不同的歌曲中选择 1 首放在第一个位置(或播放的第一首歌曲),从剩下的 9 首歌曲中选择 1 首放在第二个位置(因为已经选了 1 首),从剩下的 8 首歌曲中选择 1 首放在第三个位置(因为已经固定了 2 首),以此类推。总的播放方式可以计算如下:
data:image/s3,"s3://crabby-images/14683/14683df96d26ee280a4de16062aa112acd43f8d3" alt="{\displaystyle 10\times 9\times 8\times 7\times 6\times 5\times 4\times 3\times 2\times 1}"
将近 400 万种不同的播放列表!
现在我们将介绍阶乘函数,它是一种表达以下内容的简便方法:
data:image/s3,"s3://crabby-images/4abdc/4abdcd62c9cf56d24109bd91d04ea7a9efe4b9e9" alt="{\displaystyle n!=n\times (n-1)\times ...\times 3\times 2\times 1}"
正式定义为:
data:image/s3,"s3://crabby-images/fd071/fd071daedcd5ecc0acaa93fd4e457a44827a2074" alt="{\displaystyle {\begin{array}{l}0!=1\\n!=n\times (n-1)!\end{array}}}"
因此,在我们的例子中:
data:image/s3,"s3://crabby-images/4d924/4d9241264b5bf548cc36e309d717a4d3f87f2411" alt="{\displaystyle {\begin{array}{l}10!=10\times 9!=10\times 9\times 8!...\\10\times 9\times 8\times 7\times 6\times 5\times 4\times 3\times 2\times 1\end{array}}}"
如果我们有 30 首歌曲,但仍然只想要随机播放其中的 10 首呢?类似的推理得出以下结论:
data:image/s3,"s3://crabby-images/daee4/daee4b94bce126f7f57b513ff863383f1368a3c2" alt="{\displaystyle 30\times 29\times 28\times 27\times 26\times 25\times 24\times 23\times 22\times 21}"
种不同的方式。这等同于:
data:image/s3,"s3://crabby-images/d01a6/d01a61c2546b17335a0a9935c37f6f9952b3b018" alt="{\displaystyle {\frac {30!}{20!}}={\frac {30!}{(30-10)!}}}"
注意!阶乘函数不对加法或乘法进行分配。
一般来说,从n个项目中选取m个项目的排列数量(例如,从 30 首歌曲中选取 10 首)为:
data:image/s3,"s3://crabby-images/a7c34/a7c344d5c6383d1634dae3228ae3ee90ddc8608c" alt="{\displaystyle {\frac {n!}{(n-m)!}}}"
其背后的原理是我们取消了n!乘积中除前m个因子以外的所有因子:
data:image/s3,"s3://crabby-images/aa2dc/aa2dc748052be5fe835ea22b4a81eb1b6e080332" alt="{\displaystyle 30!=\underbrace {30\times 29\times ...\times 22\times 21} _{\text{First 10 factors}}\times \underbrace {20\times ...\times 2\times 1} _{(30-10)!=20!}}"
当m等于n时,我们说我们是在计算n个项目的排列数量。
data:image/s3,"s3://crabby-images/78cad/78cadc7c30e902eb85e9f47a506b63cd5fb95ca9" alt="{\displaystyle {\frac {n!}{(n-n)!}}={\frac {n!}{0!}}=n!}"
在解决计数问题时,我们通常会使用“项目”或“元素”(在本例中为歌曲)以及“集合”(在本例中为集合或播放列表)这些词。
1. In how many ways can I arrange my bookshelf (7 books) if I own a trilogy and the 3 books have to be always together, in the same order?
2. In how many ways can I arrange my family (6 members) in a line, with the only rule that my parents have to be in adjacent positions?
用奇素数(即3、5或7)可以组成多少个不同的两位数?75、37、77、33都是可能的解。
这是一个排列的特殊情况,项目可以选择多次。通过计数,我们发现每个位置有3种可能性,因为数字可以重复。
data:image/s3,"s3://crabby-images/5b49c/5b49c4601501e9281e6c61cc98cc5db8ee6411e8" alt="{\displaystyle \underbrace {3\times 3} _{\text{2 positions}}=3^{2}}"
9个不同的数字。
如果我们要从n个项目中选择m个,并且可能重复,那么会有
data:image/s3,"s3://crabby-images/910f1/910f12b66e83573a30f1d03cc08e20702fadde09" alt="{\displaystyle \underbrace {n\times n\times n...\times n} _{\text{m times}}=n^{m}}"
排列。
1. How many three-digit numbers can be formed with only prime digits, and odd digits may only be repeated twice?
我们可以用多少种方法让4个人(爱丽丝、鲍勃、查尔斯和唐纳德)围坐在一张圆桌旁?
这也是排列的另一种特殊情况,4个元素以环形顺序排列,排列的起点和终点是未定义的。
如果我们简单地计算
data:image/s3,"s3://crabby-images/350be/350beef39c3eb2c5749781ce0a7ed98b55307395" alt="{\displaystyle 4!}"
将会有一些重复。我们将重复计算每个独特的排列,因为像
data:image/s3,"s3://crabby-images/d0e33/d0e333ed2a8f97b82ccfb231ba1e906b17cd0ce7" alt="{\displaystyle {\begin{array}{l}{\text{A, B, C, D}}\\{\text{D, A, B, C}}\\{\text{C, D, A, B}}\\{\text{B, C, D, A}}\end{array}}}"
被认为是等价的。请记住,圆桌没有起点。
有4个人椅子和4组等价排列,这并非巧合。
如果我们任意给椅子编号,我们可以通过循环整个布局来获得所有等价的排列。我们会循环多少次?有多少个椅子/位置?4个。
将我们的第一个意图除以4(即将4个等价布置分组)
data:image/s3,"s3://crabby-images/2b58d/2b58decd1e014373adc82d6af5626ce9ddc59d4a" alt="{\displaystyle {\frac {4!}{4}}=3!}"
6个唯一的布置。
另一种方法是强制定义布局的任意起点,换句话说,固定一个元素并排列剩下的3个元素
data:image/s3,"s3://crabby-images/18cbd/18cbd05ada544a0d70ad95ccfbebba494d9885e7" alt="{\displaystyle (4-1)!=3!=6}"
方法让四个人围坐在一张圆桌旁。
1. What if there are 7 people, but the table only has 5 chairs?
在数学课的15名学生中,将选出5名学生代表班级参加全校数学竞赛。有多少种方法可以选择这5名学生?
这种类型的问题称为无序选择(组合),因为选择学生的顺序并不重要。例如,以下选择被认为是等价的
data:image/s3,"s3://crabby-images/24eda/24eda2f2a91cd618461b6e0439364bc09df34849" alt="{\displaystyle {\begin{array}{l}{\text{Joe, Lee, Sue, Violet, Justin}}\\{\text{Lee, Joe, Sue, Justin, Violet}}\end{array}}}"
如前所述,有
data:image/s3,"s3://crabby-images/b69e5/b69e5e068f6face2a986d8a9fd708344fe3b2f93" alt="{\displaystyle {\frac {15!}{10!}}}"
种方法以有序选择方式选择5名候选人,但对于每个不同的组合,有5!种有序选择(即相同的5名学生)。这意味着我们为每个组合都计算了5!次。因此,有
data:image/s3,"s3://crabby-images/ea86a/ea86a3c91e4dfc49821905d8447c5f0c54555ede" alt="{\displaystyle {\frac {15!}{10!\times 5!}}}"
种方法选择5名学生代表班级。
一般来说,从n个项目中选择m个项目的种数为
data:image/s3,"s3://crabby-images/a33a5/a33a5604825f75dd3a3563b0c02eff95bf3d514f" alt="{\displaystyle {\frac {n!}{(n-m)!\times m!}}}"
我们拿出了从 *n* 个项目中选出 *m* 个项目的排列公式,然后除以 *m*!,因为每个组合都被计算了 *m*! 个有序的选择(*m*! 次)。
这个公式用以下符号表示:
data:image/s3,"s3://crabby-images/32e6e/32e6eec3e2e1a0ba13dc21a6fecc1aa5446cbab1" alt="{\displaystyle {n \choose m}={\frac {n!}{(n-m)!\times m!}}}"
注意,
通常读作 *从 n 中选 m*。
1. Try not to use a calculator and think of the problem with groups of 1 student.
2. Again, no calculator and this time there are 1 million students in the class and we want to form groups of 999,999 students.
在这种特殊的组合问题情况下,元素可以被选择多次。也就是说,组可以包含同一个元素的多个样本。
知道哪些元素被采样不足以定义一个选择,我们需要知道 **每个元素被选择的次数** (即该元素被选择的样本数量)。本质上,这两种方法是相同的,因为说一个元素被选择了 0 次等同于说它没有被采样。
现在假设我们要从 *n* 个元素中选出 *m* 个元素。我们不应该把这个问题看成是 "从 *n* 个元素中选择 *m* 次",而应该把它看成是 "将 *m* 个可用位置分配给 *n* 个不同的元素"(表示将 *m* 个元素放入 *n* 个集合中)。同样,这两种解释是等效的,因为元素被选择的次数由其对应集合中元素的数量表示。
为了定义一个选择,我们把每个集合中放入了与我们从该集合所代表的元素中选择的样本一样多的对象。我们可以创建一个字符串来标识选择,例如用一个方块来表示每个对象(样本),用一个短横线来表示集合边界
data:image/s3,"s3://crabby-images/5e813/5e813e6ec9ed70b624a6281dbe26b74b3f80ad56" alt="{\displaystyle -\underbrace {{\blacksquare }{\blacksquare }{\blacksquare }} _{\text{First set/element}}-\underbrace {{\blacksquare }{\blacksquare }} _{\text{Second set/element}}-\underbrace {{\blacksquare }{\blacksquare }} _{\text{Third set/element}}-}"
这意味着三个位置被分配给第一个元素,两个位置被分配给第二个元素,两个位置被分配给第三个元素。换句话说,该选择包含三个第一类元素,两个第二类元素,两个第三类元素。该字符串可以代表一个随机的五个字母组成的字母组,仅包含字母 A,B,C
data:image/s3,"s3://crabby-images/91ca0/91ca0ab440139ce760903bf2357efa517b8f3a43" alt="{\displaystyle {\text{A, A, A, B, B, C, C}}}"
连接的字符串由 *m* 个方块和 *n + 1* 个短横线组成。例如,以下代表从五个元素中选出的三个元素
data:image/s3,"s3://crabby-images/d169f/d169fa6ca98a9d733775d4e671188261b5548395" alt="{\displaystyle -\underbrace {{\blacksquare }{\blacksquare }} _{\text{First set/element}}-\underbrace {} _{\text{Second set/element}}-\underbrace {\blacksquare } _{\text{Third set/element}}-\underbrace {} _{\text{Forth set/element}}-\underbrace {} _{\text{Fifth set/element}}-}"
注意,除了固定在字符串开头和结尾的两个短横线外,其他 *n - 1* 个短横线和 *m* 个方块可以移动,而不会使字符串无效。因此,在 *n - 1 + m* 个位置中,有 *n - 1 + m* 个可移动字符。可能的字符串数量等于将 *m* 个方块放在 *n - 1 + m* 个字符中的方法数量,换句话说,是从 *n - 1 + m* 个位置中选出 *m* 个位置的方法数量
data:image/s3,"s3://crabby-images/1c6b3/1c6b33a0dfb92fc0d2d61d93f85e07c92a90a2fe" alt="{\displaystyle {{n-1+m} \choose {m}}}"
等效地,我们可以谈论将 *n - 1* 个短横线放在 *n - 1 + m* 个字符中的位置
data:image/s3,"s3://crabby-images/2e343/2e3432f525f5eb8809be4163512065b0fa38fe49" alt="{\displaystyle {{n-1+m} \choose {n-1}}}"
由于每个字符串都独一无二地确定一个选择或组,因此字符串的数量显然等同于可能的组或选择的数量。
如果我们要为长途旅行打包三种水果,而你只有香蕉、苹果、橙子、桃子和奇异果,那么会有
data:image/s3,"s3://crabby-images/bf83c/bf83c68f703ce48d9abd7d81d070f0dc4b478f71" alt="{\displaystyle {{5-1+3} \choose {3}}={{5-1+3} \choose {5-1}}=35}"
可能的打包组。
二项式系数
data:image/s3,"s3://crabby-images/eceeb/eceeb78564909784edb764df454f211e9b3f4d5e" alt="{\displaystyle {n \choose m}}"
表示从包含n个元素的集合中选择m个元素可以形成的无序组的数量。
以下是一些基本且有用的属性
- 从n个元素中选择m个元素的方式数量等于从n个元素中选择n-m个元素的方式数量,因为每个选定元素组都有一个相应的未选定元素组。选定元素组定义了另一个未选定元素组。
data:image/s3,"s3://crabby-images/ab1a5/ab1a5a53669c87b6f868b4dba30f2996970595fc" alt="{\displaystyle {n \choose m}={n \choose {n-m}}}"
data:image/s3,"s3://crabby-images/fc49c/fc49ceae4a525e9c30cb9ec91333e8d5ec235c18" alt="{\displaystyle {n \choose 0}={n \choose n-0}=1}"
data:image/s3,"s3://crabby-images/3fb61/3fb6160efb63289d753237549223784a4b7dc958" alt="{\displaystyle {n \choose 1}={n \choose {n-1}}=n}"
data:image/s3,"s3://crabby-images/eceeb/eceeb78564909784edb764df454f211e9b3f4d5e" alt="{\displaystyle {n \choose m}}"
- 和
data:image/s3,"s3://crabby-images/b6956/b695673ee23828adbe51c50bc085437d88e33b42" alt="{\displaystyle {{n+1} \choose m}}"
- 在于第一个公式没有计算包含在第二个公式中添加的元素的组。包含来自包含n+1个元素的集合中的特定元素的m大小的组的数量是
data:image/s3,"s3://crabby-images/8c6f9/8c6f9cbe37b99f33d1889debc0d5ba037286951d" alt="{\displaystyle {{(n+1)-1} \choose {m-1}}={n \choose {m-1}}}"
- 因此
data:image/s3,"s3://crabby-images/eedf7/eedf7d107de2591140ab0f54c74077b1f40672c7" alt="{\displaystyle {{n+1} \choose m}={n \choose m}+{n \choose {m-1}}}"
data:image/s3,"s3://crabby-images/4b4db/4b4db6a870ef9a4f26ec13f71c3c79a001b151a7" alt="{\displaystyle {n \choose {m+1}}}"
- 和
data:image/s3,"s3://crabby-images/eceeb/eceeb78564909784edb764df454f211e9b3f4d5e" alt="{\displaystyle {n \choose m}}"
- 在于第一个公式计算的组比第二个公式计算的组多一个元素。每个m大小的组需要n-m中剩余的“缺失”元素中的一个才能增长到m+1大小。
data:image/s3,"s3://crabby-images/eacea/eaceaea6038c9e998d9301233c30ada898fa99c6" alt="{\displaystyle {n \choose m}\times (n-m)}"
- 但是,我们必须观察到我们多次计算每个m+1大小的组,实际上是m+1次。这是因为“缺失”的元素可以是结果组中的m+1个元素中的任何一个,换句话说,m+1个m大小的组(当与正确的元素关联时)将形成同一个m+1大小的组。从m+1大小的组中移除一个元素可以形成多少个m大小的组?
data:image/s3,"s3://crabby-images/8fc25/8fc257458d8496022b96ccb7b05478104647e7b0" alt="{\displaystyle {{m+1} \choose 1}=m+1}"
- 这表明
data:image/s3,"s3://crabby-images/7f813/7f81340f26162dda7486d8901785b87e938a64b9" alt="{\displaystyle {n \choose {m+1}}={n \choose m}\times {\frac {n-m}{m+1}}}"
二项式定理描述了以下表达式的代数展开
data:image/s3,"s3://crabby-images/2dd6c/2dd6cd82b74057ba28f233caba836d38d28adb80" alt="{\displaystyle (a+b)^{n}}"
例如,取 *n* = 2,我们将尝试手动展开表达式,得到
data:image/s3,"s3://crabby-images/a50dd/a50ddfb21861cc9c7a98ec088ea670435688da0e" alt="{\displaystyle (a+b)^{2}=(a+b)(a+b)=aa+ab+ba+bb}"
取 *n* = 3
data:image/s3,"s3://crabby-images/71d65/71d6518cb2145e910adc6d659a023cf474c3b020" alt="{\displaystyle (a+b)^{3}=(a+b)(a+b)(a+b)=aaa+aab+aba+abb+baa+bab+bba+bbb}"
在展开过程中,我们故意没有对表达式进行简化。正如你所看到的,最终展开的形式分别有四项和八项。这些项都是 *a* 和 *b* 在两个和三个因子的乘积中所有可能的组合。
因子的数量等于第一个乘积中二项式 *(a + b)* 的数量,而这反过来又等于 *n*。
在
data:image/s3,"s3://crabby-images/2dd6c/2dd6cd82b74057ba28f233caba836d38d28adb80" alt="{\displaystyle (a+b)^{n}}"
中,每一项都有 *n* 个因子。有多少项只有一个 *b*?换句话说,我可以在 *n* 个不同位置中放置一个 *b* 有多少种方法?或者更好的是,我可以在 *n* 个位置中选择一个位置(放置一个 *b*)有多少种方法?
data:image/s3,"s3://crabby-images/eaf5f/eaf5f165b73572901bd973b9f49578181ee8b2c7" alt="{\displaystyle {n \choose 1}}"
类似地,我们可以计算出其他所有项的系数
data:image/s3,"s3://crabby-images/2880d/2880db466e87ff2d32e17eb8b655bef91218c8bc" alt="{\displaystyle (a+b)^{3}={3 \choose 0}a^{3}+{3 \choose 1}a^{2}b+{3 \choose 2}ab^{2}+{3 \choose 3}b^{3}}"
更一般地说
data:image/s3,"s3://crabby-images/000db/000db1265774362116fbc74fe7cac73a95689828" alt="{\displaystyle (a+b)^{n}={n \choose 0}a^{n}+{n \choose 1}a^{n-1}b+{n \choose 2}a^{n-2}b^{2}+...{n \choose n-1}ab^{n-1}+{n \choose n}b^{n}}"
或者更简洁地使用求和运算符
data:image/s3,"s3://crabby-images/547c1/547c1651e46ad78b3fc07cda4b87e92ea99dd69e" alt="{\displaystyle (a+b)^{n}=\sum _{i=0}^{n}{n \choose i}a^{n-i}b^{i}}"