| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 636 人关注过本帖
标题:[求助]用逆归法求5!
只看楼主 加入收藏
adam1600
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2008-3-1
收藏
 问题点数:0 回复次数:9 
[求助]用逆归法求5!
最后输出的结果是24,还少乘了一阶。
想了一下午都还想不明白为什么,求高手帮助!谢谢。
///////////////////////////////////////////////////////////
#include"stdio.h"
int jc(int n);
void main()
{
    printf("!5=%d\n",jc(5));
}

int jc(int n)
{
    if(n!=1)
        return n*jc(--n);
    else
        return 1;
}
///////////////////////////////////////////////////////////
2008-08-06 23:10
blueboy82006
Rank: 5Rank: 5
来 自:幻想世界
等 级:贵宾
威 望:16
帖 子:1227
专家分:57
注 册:2007-7-23
收藏
得分:0 
问题就在你的
--n
这句。。。

2008-08-06 23:36
blueboy82006
Rank: 5Rank: 5
来 自:幻想世界
等 级:贵宾
威 望:16
帖 子:1227
专家分:57
注 册:2007-7-23
收藏
得分:0 
你这样试一下:
#include"stdio.h"
int jc(int n);
void main()
{
    printf("5!=%d\n",jc(5));
}

int jc(int n)
{
    int t;
    if(n!=1)
    {
        t=n-1;
        return n*jc(t);
    }
    else
        return 1;
}

2008-08-06 23:36
adam1600
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2008-3-1
收藏
得分:0 
可我用n--没有输出任何结果
2008-08-06 23:37
adam1600
Rank: 1
等 级:新手上路
帖 子:23
专家分:0
注 册:2008-3-1
收藏
得分:0 
正确输出 谢谢
2008-08-06 23:41
zjl138
Rank: 1
等 级:新手上路
威 望:1
帖 子:788
专家分:0
注 册:2007-11-12
收藏
得分:0 
3楼代码很不严谨的说...

i like linux...
2008-08-07 00:20
kissmahao
Rank: 1
来 自:山东聊城
等 级:新手上路
帖 子:6
专家分:0
注 册:2007-5-20
收藏
得分:0 
有的编译系统求值是按从右至左的顺序, 所以先算--n, 再用--n的值*jc(n),

2008-08-08 14:19
很远的那颗星
Rank: 2
等 级:新手上路
威 望:4
帖 子:544
专家分:0
注 册:2008-6-30
收藏
得分:0 
直接在这里敲的
#include<stdio.h>
int jc(int n)
{
    if (n<0) return -1;   //
    else return (n==0 || n==1) ? 1 : n*jc(n-1);
}
int main(void)
{
   int a;
   scanf("%d",&a);   //一开始忘了写输入...
   printf("a!=%d\n",jc(a));
}


[[it] 本帖最后由 很远的那颗星 于 2008-8-8 17:28 编辑 [/it]]

Fighting~~~~~~~~
2008-08-08 17:24
hundnn
Rank: 1
等 级:新手上路
帖 子:123
专家分:0
注 册:2007-8-23
收藏
得分:0 
#include <stdio.h>
int jc(int n);

void main()
{
    printf("5!=%d\n",jc(5));
}

int jc(int n)
{
    if(n!=1)
    return n*jc(n-1);
    else return 1;
}

/*********下面跟大家开个玩笑***************/
#include <stdio.h>
void main()
{
    int a[6],i,m=1;

    for(i=1;i<=5;i++)
        a[i] = i;
    for(i=1;i<=5;i++)
        m*=a[i];
    printf("5!=%d\n",m);

}
/*****************************************/
2008-08-08 17:41
很远的那颗星
Rank: 2
等 级:新手上路
威 望:4
帖 子:544
专家分:0
注 册:2008-6-30
收藏
得分:0 
[bo][un]hundnn[/un] 在 2008-8-8 17:41 的发言:[/bo]

int jc(int n)
{
    if(n!=1)
    return n*jc(n-1);
    else return 1;
}
 

大家都这么写,不知 n==0 时会发生什么情况..

Fighting~~~~~~~~
2008-08-08 18:41
快速回复:[求助]用逆归法求5!
数据加载中...
 
   



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

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