组合数并不陌生(´・ω・`)

我们都学过组合数

会求组合数吗

一般我们用杨辉三角性质

杨辉三角上的每一个数字都等于它的左上方和右上方的和(除了边界)

第n行,第m个就是,就是C(n, m) (从0开始)

电脑上我们就开一个数组保存,像这样

用递推求

 #include<cstdio>
const int N = + ;
const int MOD = (int)1e9 + ;
int comb[N][N];//comb[n][m]就是C(n,m)
void init(){
for(int i = ; i < N; i ++){
comb[i][] = comb[i][i] = ;
for(int j = ; j < i; j ++){
comb[i][j] = comb[i-][j] + comb[i-][j-];
comb[i][j] %= MOD;
}
}
}
int main(){
init();
}

(PS:大部分题目都要求求余,而且大部分都是对1e9+7这个数求余)

这种方法的复杂度是O(n^2),有没有O(n)的做法,当然有(´・ω・`)

因为大部分题都有求余,所以我们大可利用逆元的原理(没求余的题目,其实你也可以把MOD自己开的大一点,这样一样可以用逆元做)

根据这个公式

我们需要求阶乘和逆元阶乘

我们就用1e9+7来求余吧

代码如下:

 #include<cstdio>
const int N = + ;
const int MOD = (int)1e9 + ;
int F[N], Finv[N], inv[N];//F是阶乘,Finv是逆元的阶乘
void init(){
inv[] = ;
for(int i = ; i < N; i ++){
inv[i] = (MOD - MOD / i) * 1ll * inv[MOD % i] % MOD;
}
F[] = Finv[] = ;
for(int i = ; i < N; i ++){
F[i] = F[i-] * 1ll * i % MOD;
Finv[i] = Finv[i-] * 1ll * inv[i] % MOD;
}
}
int comb(int n, int m){//comb(n, m)就是C(n, m)
if(m < || m > n) return ;
return F[n] * 1ll * Finv[n - m] % MOD * Finv[m] % MOD;
}
int main(){
init();
}

组合大法好,要懂得善加利用(。-`ω´-)

最新文章

  1. 我的屌丝giser成长记-工作篇之B公司
  2. pageX、clientX、screenX、offsetX、layerX、x
  3. PHP 转换接口编码
  4. 简单LRU算法实现缓存
  5. myeclipse 配置svn资源库
  6. 在页面中使用Eval的两种方案
  7. java新手笔记26 Frame
  8. VSS的运用小内容(针对于vs2008版本)(小的问题都是,仅供参考--只针对于菜鸟级的)
  9. 《UNIX环境高级编程》笔记--chown,fchown和lchown函数
  10. STL中vector,Map,Set的实现原理
  11. php language construct 语言构造器
  12. 类是公共,它应该被命名为.java文件声明
  13. 2016 ACM Amman Collegiate Programming Contest D Rectangles
  14. 第二节 安装CentOS
  15. 关于js中循环遍历中顺序执行多个嵌套ajax的问题
  16. linux C遍历目录下文件
  17. linux部分常见指令
  18. input框的输入限制
  19. C++ 智能指针四
  20. happyxiaofan的程序员书单

热门文章

  1. Flutter - 下载别人的Flutter项目,本地编译不过
  2. Linux shell 编写(2)
  3. 1.21 贪心入门上午PAT例题题解
  4. 私有云搭建:树莓派+kodexplorer可道云,几步搞定!
  5. dom学习要点
  6. python 根据年月日,计算是这一年中的第几天
  7. [朴孝敏][Road Trip]
  8. wc命令详解
  9. lscpu命令详解
  10. PyCharm配置SFTP远程调试Django应用