练习2-18 求组合数 (15 分)

本题要求编写程序,根据公式练习2-18 求组合数 (15 分)算出从n个不同元素中取出m个元素(m≤n)的组合数。

建议定义和调用函数 fact(n) 计算 n! ,其中 n 的类型是 int ,函数类型是 double 。

输入格式:

输入在一行中给出两个正整数m和n(m≤n),以空格分隔。

输出格式:

按照格式“result = 组合数计算结果”输出。题目保证结果在double类型范围内。

输入样例:

2 7

输出样例:

result = 21

提交:

#include <stdio.h>

double fact(int n){//这里要用 double类型,否则 m = n/2会不通过
    if (n==0) return 1;
    else return fact(n-1)*n;
};

int main(){
    int m,n;
    double result;
    scanf("%d %d",&m,&n);
    result = fact(n)/(fact(m)*fact(n-m));
    printf("result = %.0lf",result);
    return 0;
}

 

上一篇:PTA 1 斐波那契数列(I)


下一篇:信息学奥赛一本通(2019:【例4.4】求阶乘)