|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
#include <stdio.h>
int combination(int n,int r)
{
if (r > 1)
return (combination(n-1,r-1) + combination(n-1,r));
else if (r == 1)
return n;
else if (r == n || r == 0)
return 1;
}
int main(void)
{
int n,r;
scanf("%d%d",&n,&r);
printf("%d",combination(n,r));
return 0;
}
编写程序,从n个不同整数中取出r个整数的组合数Crn(使用递归函数)
问题描述:
这个问题要求编写一个递归函数来计算从n个不同整数中取出r个整数的组合数Crn。
解决方案:
递归函数的实现如下:
#include <stdio.h>
int combination(int n, int r)
{
if (r > 1)
return (combination(n - 1, r - 1) + combination(n - 1, r));
else if (r == 1)
return n;
else if (r == n || r == 0)
return 1;
}
int main(void)
{
int n, r;
scanf("%d%d", &n, &r);
printf("%d", combination(n, r));
return 0;
}
在递归函数combination中,我们使用了三个if语句来处理不同的情况:
1. 如果r大于1,我们将问题分解为两个子问题,分别是从n-1个整数中取出r-1个整数的组合数和从n-1个整数中取出r个整数的组合数,然后将它们相加得到结果。
2. 如果r等于1,我们直接返回n,因为从n个整数中取出1个整数的组合数就是n本身。
3. 如果r等于n或者r等于0,我们直接返回1,因为从n个整数中取出n个整数或者取出0个整数的组合数都只有一种情况。
在主函数main中,我们首先读取输入的n和r,然后调用递归函数combination来计算组合数,并将结果输出。
希望能帮到你!
|
|