组合数计算
(本文为笔者的个人学习笔记,如有不当之处恳请各位读者指正)
定义:从m个不同元素中,任取n(n≤m)个元素并成一组,叫做从m个不同元素中取出n个元素的一个组合;从m个不同元素中取出n(n≤m)个元素的所有组合的个数,叫做从m个不同元素中取出n个元素的组合数,记作。
计算公式:
例如:在26个字母中取出3个字母,共有种取法。
在此例题中将26的阶乘交给计算机计算,你会发现在计算结果超出了long long型数值的范围而发生溢出错误。所以在编程计算组合数时如果直接使用该公式计算不仅可能会发生溢出错误而且时间复杂度也高。避免发生溢出错误的一个方法是对进行约分。
原公式可化简为:
在计算的过程中还可以利用组合数的互补性质来减少计算量,例如与的值是相等的,但前者的计算量要少很多。
long long C(int m, int n){
if(n < m-n)
n = m-n;
long long ans = 1;
for(int i=m;i>=n+1;i--)
ans*=i;
for(int i=1;i<=m-n;i++)
ans/=i;
return ans;
}