排列组合专题

加法原理

若完成一件事的方法有 n n n类,其中第 i i i类方法包括 a i a_i ai种不同的方法,且这些方法互不重合,则完成这件事情共有 ∑ a i \sum a_i ai种方法。


乘法原理

若完成一件事需要 n n n个步骤,其中第 i i i个步骤有 a i a_i ai种不同方法,且这些步骤互不干扰,则完成这件事共有 ∏ a i \prod a_i ai种方法


排列

定义

n n n个不同元素中选出 m m m个排成一列,问产生的排列数量
P n m = n ! ( n − m ) ! = ∏ i = 0 m − 1 ( n − i ) P_{n}^{m}=\frac{n!}{(n-m)!}=\prod_{i=0}^{m-1}(n-i) Pnm=(nm)!n!=i=0m1(ni)


组合

定义

n n n个不同元素中选择 m m m个,不考虑次序,问方案数
C n m = n ! m ! ( n − m ) ! = P n m m ! C_{n}^{m}=\frac{n!}{m!(n-m)!}=\frac{P_{n}^{m}}{m!} Cnm=m!(nm)!n!=m!Pnm


性质

  1. C n m = C n n − m C_{n}^{m}=C_{n}^{n-m} Cnm=Cnnm
  2. C n m = C n − 1 m − 1 + C n − 1 m C_{n}^{m}=C_{n-1}^{m-1}+C_{n-1}^{m} Cnm=Cn1m1+Cn1m
  3. ( ∑ i = 0 n C n i ) = 2 n (\sum_{i=0}^{n}C_{n}^{i})=2^n (i=0nCni)=2n

POJ 1942 Paths on a grid

题目

给定一个 n ∗ m n*m nm的格子,问从左上角向上或向右走到右上角的方案数


分析

那么可以这样想,也就是题目求在 n + m n+m n+m个方向中选出 n n n个向右的方案数,那也就是 C n + m n C_{n+m}^{n} Cn+mn,然而这道题虽然好像数据很大,实际上数据非常弱,嗯,代码我就不贴了


二项式定理

定义

( a + b

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值