| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 314 人关注过本帖
标题:一道递归函数题纠错
只看楼主 加入收藏
雪天
Rank: 1
等 级:新手上路
帖 子:18
专家分:5
注 册:2009-7-23
结帖率:40%
收藏
已结贴  问题点数:20 回复次数:3 
一道递归函数题纠错
设计一个递归函数计算1!+2!+3!+……+n!。

我的程序:
#include"stdio.h"
void main()
{
    int n;
    long sum;
    long F(int n);
    printf("输入n:");
    scanf("%d",&n);
    sum=F(n);
    printf("1!+2!+...+%d!=%ld\n",n,sum);
}
long F(int n)
{
    long fac(int);
    long f;
    if(n==0)
        f=0;
    else f=fac(n)+F(n-1);
    return f;
}
long fac(int n)
{
    long f;
    if(n==0)
        f=1;
    f=n*fac(n-1);
    return f;
}
上面的程序编译成功,运行失败...........各位大侠,help!~~~~~~~
搜索更多相关主题的帖子: 递归函数 
2009-07-23 22:41
wxjeacen
Rank: 7Rank: 7Rank: 7
等 级:禁止访问
帖 子:1291
专家分:628
注 册:2009-3-22
收藏
得分:10 
程序代码:
#include"stdio.h"
typedef long long elemtype;
elemtype F(int );
elemtype fac(int );
int  main()
{
    int n;
    long sum;
    
    printf("输入n:");
    scanf("%d",&n);
    sum=F(n);
    printf("1!+2!+...+%d!=%ld\n",n,sum);
    return 0;
}
elemtype F(int n)
{
    
    elemtype f;
    if(n==0)
        f=0;
    else f=fac(n)+F(n-1);
    return f;
}
elemtype fac(int n)
{
    if(n==0)
        return 1;
    else
        return n*fac(n-1);
}

生命不熄,战斗不止.
2009-07-24 09:35
zmgaode7
Rank: 2
等 级:论坛游民
帖 子:7
专家分:18
注 册:2009-7-3
收藏
得分:5 
在f()函数调用fac()函数前,没有对fac()进行说明。。。。
2009-07-24 11:33
wxjeacen
Rank: 7Rank: 7Rank: 7
等 级:禁止访问
帖 子:1291
专家分:628
注 册:2009-3-22
收藏
得分:5 
回复 3楼 zmgaode7
在函数里面声明的。

生命不熄,战斗不止.
2009-07-24 11:48
快速回复:一道递归函数题纠错
数据加载中...
 
   



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

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