组合数计算

组合数计算

(本文为笔者的个人学习笔记,如有不当之处恳请各位读者指正)


定义:从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;
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值