练习2-18 求组合数
浙大版《C语言程序设计(第3版)》
题目
本题要求编写程序,根据公式
算出从n个不同元素中取出m个元素(m≤n)的组合数。
建议定义和调用函数fact(n)计算n!,其中n的类型是int,函数类型是double。
输入格式:
输入在一行中给出两个正整数m和n(m≤n),以空格分隔。
输出格式:
按照格式“result = 组合数计算结果”输出。题目保证结果在double类型范围内。
输入样例:
输出样例:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
double fact(int n)//求阶乘
{
double pro = 1;//应为0!=1,1!=1,这里pro的初始值设为1,是为了处理传入0的情况
for (int i = n; i > 0; i--)
{
pro = pro*i;
}
return pro;
}
int main()
{
int m, n;
double result = 0;
scanf("%d %d", &m, &n);
result = fact(n) / (fact(m)*fact(n - m));
printf("result = %.0f\n", result);//%。0f指定输出时不要小数部分
system("pause");
return 0;
}