| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3303 人关注过本帖
标题:小白求助,递归函数求阶乘,输入18以上数值输出了负值。。。
只看楼主 加入收藏
Alice1202
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2015-8-7
结帖率:0
收藏
已结贴  问题点数:20 回复次数:3 
小白求助,递归函数求阶乘,输入18以上数值输出了负值。。。
各位大大们好
我在写一个递归函数求阶乘的函数的c程序时,n取值在0~17一直没有错误,但是从18开始一直输出负值。。。n取18时,输出的是-898433024,正确结果应为640237373705728000
多谢各位!
程序如下:
程序代码:
#include <stdio.h>
int factoriel(int n)
{
    int result;
    if(n<0)
    {
        printf("输入错误\n");
        return 0;
    }
    else if(n==0||n==1)
    {
        result =1;
    }
    else
    {
        result = factoriel(n-1)*n;
    }
    return result; 
} 
int main()
{
    int n = 9;
    printf("the factoriel of %d is egale at %d",n,factoriel(n));
    return 0;
}

搜索更多相关主题的帖子: result c程序 
2016-02-06 02:47
米线儿
Rank: 2
等 级:论坛游民
威 望:1
帖 子:35
专家分:54
注 册:2015-3-28
收藏
得分:7 
因为计算结果超出int的取值范围了,所以会出现负数。

你可以用printf打印出你计算机int类型的极大值和极小值确定一下。
收到的鲜花
  • 杭012016-02-11 16:01 送鲜花  1朵  
2016-02-06 05:42
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:7 
教你一个简单的办法吧
打开windows自带的计算器,计算18的阶乘,得 6402373705728000,计算 ln(6402373705728000)/ln(2) 得 52.5,也就是 18! 需要 53bits 存储
收到的鲜花
  • 杭012016-02-11 16:02 送鲜花  1朵  
2016-02-06 08:24
锄禾当午
Rank: 2
等 级:论坛游民
帖 子:12
专家分:34
注 册:2016-2-8
收藏
得分:7 
应该用long int
收到的鲜花
  • 杭012016-02-11 16:01 送鲜花  1朵   附言:我很赞同
2016-02-10 11:22
快速回复:小白求助,递归函数求阶乘,输入18以上数值输出了负值。。。
数据加载中...
 
   



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

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