Java教程

练习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;
}

 

这篇关于练习2-18 求组合数 (15 分)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!