| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1825 人关注过本帖
标题:C语言求组合数
只看楼主 加入收藏
Z1020
Rank: 1
等 级:新手上路
帖 子:63
专家分:5
注 册:2019-11-9
结帖率:85.71%
收藏
已结贴  问题点数:20 回复次数:2 
C语言求组合数
本题要求编写程序,根据公式C
n
m
 =
m!(n−m)!
n!
 算出从n个不同元素中取出m个元素(m≤n)的组合数。

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

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

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

输入样例:
2 7

输出样例:
result = 21
我的代码是
#include<stdio.h>
int n,m,h;
double fact(int n,int m);
int main()
{   
//    double re;
    scanf("%d%d",&m,&n);
    h=n;
//    re=fact(n)/fact(m)*fact(n-m);
    printf("result = %lf",fact(n,m));
}
double fact(int n,int m)
{
    int sum=1,sum1=1,i;
    double re;
    for(i=m;i>=1;i--)
    {
        sum=sum*i;
    }
    for(i=1;i<=n-m;i++,h--)
    {
        sum1=sum1*h;
    }
    re=sum1/sum;
    return re;
}
希望大佬能解答一下,我的编程遇到瓶颈了
搜索更多相关主题的帖子: double 组合 int 输入 sum 
2019-12-23 13:57
永远没有永远
Rank: 2
等 级:论坛游民
帖 子:12
专家分:20
注 册:2019-10-5
收藏
得分:20 
fact函数中 for(i=1;i<=n-m;i++,h--)
     {
         sum1=sum1*h;
     }
应改为
 for(i=1;i<=m;i++,h--)
     {
         sum1=sum1*h;
     }
因为C(m,n)是m!/(n*(n-1)*……(n-m+1)
分母共m个
2019-12-24 15:52
Z1020
Rank: 1
等 级:新手上路
帖 子:63
专家分:5
注 册:2019-11-9
收藏
得分:0 
回复 2楼 永远没有永远
谢谢谢谢
2019-12-26 21:36
快速回复:C语言求组合数
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016253 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved