C语言排列组合问题的快速算法

求C(m,n),即n!/(m!*(n-m)!),结果对1000000007取模。需要解决伪溢出问题,最高效率的算法是什么。... 求C(m,n),即n!/(m!*(n-m)!),结果对1000000007取模。
需要解决伪溢出问题,最高效率的算法是什么。
展开
 我来答
百度网友d580670
2015-09-25 · TA获得超过1983个赞
知道大有可为答主
回答量:2054
采纳率:82%
帮助的人:708万
展开全部

#include "math.h"
typedef unsigned int uint32;
uint32 C(uint32 m, uint32 n)
{
double res = 0;
uint32 i, ires;
for (i = n-m+1; i <= n; i++) res += log(i);
for (i = 2; i <= m; i++)     res -= log(i);
res = exp(res);
ires = (uint32) res;
if ((uint32)(res + 0.5) != ires ) ires++;
return ires % 1000000007;
}
int main()
{
    printf("C(2,3) = %d C(2, 10) = %d C(3, 1000)= %d\n",
C(2,3), C(2, 10), C(3, 1000));
return 0;
}
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式