| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3560 人关注过本帖
标题:求C语言用递归实现排列组合的数据太大就会溢出的问题!
取消只看楼主 加入收藏
wjfko
Rank: 1
等 级:新手上路
帖 子:15
专家分:3
注 册:2012-2-19
结帖率:75%
收藏
已结贴  问题点数:20 回复次数:3 
求C语言用递归实现排列组合的数据太大就会溢出的问题!
#include<stdio.h>
long jc(int n)
{
    if(n==0) return 1;//0的阶乘等于1
    else return n*jc(n-1);//n的阶乘等于n乘以(n-1)的阶乘
}

long zh(int m,int n)
{
    long i;
    i=jc(m)/(jc(n)*jc(m-n));//组合公式
    return i;
}
void main()
{
    int m,n;
    printf("请输入总数目和需要取出的数目:\n");
    scanf_s("%d%d",&m,&n);
    printf("%ld",zh(m,n));
}

以上是我写的部分,但是如果输入的数据稍微大一点就执行不通过了,请问该如何解决?
搜索更多相关主题的帖子: long return C语言 如何 
2012-02-20 13:15
wjfko
Rank: 1
等 级:新手上路
帖 子:15
专家分:3
注 册:2012-2-19
收藏
得分:0 
我把long改成double又计算不出来,结果都是0了!
2012-02-20 13:44
wjfko
Rank: 1
等 级:新手上路
帖 子:15
专家分:3
注 册:2012-2-19
收藏
得分:0 
以下是引用laoyang103在2012-2-20 13:45:57的发言:

看来楼主没明白我的意思   我是让你用字符串来存浮点数 然后去进行乘除运算
 
我想你看下这道题你就会明白了
 
http://
你发来的是个题目么?
全是E文,不太明白。
请问您能否把我的代码改一下了贴上来让我看看?
万分感谢!
2012-02-20 14:44
wjfko
Rank: 1
等 级:新手上路
帖 子:15
专家分:3
注 册:2012-2-19
收藏
得分:0 
谢谢你!
2012-02-21 16:23
快速回复:求C语言用递归实现排列组合的数据太大就会溢出的问题!
数据加载中...
 
   



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

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