| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 348 人关注过本帖
标题:打家看看这个递归的 为什么结果要存起来 不能直接返回T 求N的阶乘的递归 ...
只看楼主 加入收藏
专打小拉拉啊
Rank: 1
等 级:新手上路
帖 子:3
专家分:0
注 册:2010-12-6
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:2 
打家看看这个递归的 为什么结果要存起来 不能直接返回T 求N的阶乘的递归都不要存结果
#include<stdio.h>
#include <string.h>
int step[41];

int main()
{
    int a,n,c;
    int f1(int x);
    memset(step,0,sizeof(step)); // 初始化
    scanf("%d",&n);
    while(n--)
    {
        scanf("%d",&a);
        c=f1(a);
        printf("%d\n",c);
    }   
}


int f1(int x)
{
    int t;
    if(step[x]!=0)
        return step[x]; // 如果存过了, 直接返回结果
    if(x==2||x==1)
        t=1;
    else t=f1(x-1)+f1(x-2);
    step[x] = t; // 存起来
    return t;
}
搜索更多相关主题的帖子: return 
2011-05-05 15:54
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:10 
干嘛要存起来, 直接返回简单。
程序代码:
int fac (int n) {
    if(n==0) return 1;
    else return n*fac(n-1);
}

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-05 16:45
BlueGuy
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:29
帖 子:4476
专家分:4055
注 册:2009-4-18
收藏
得分:10 
避免重复运算。
因为求 N!的算法是线性级的; 而这个不是,这个是指数级的。

[ 本帖最后由 BlueGuy 于 2011-5-5 17:29 编辑 ]

我就是真命天子,顺我者生,逆我者死!
2011-05-05 17:28
快速回复:打家看看这个递归的 为什么结果要存起来 不能直接返回T 求N的阶乘的 ...
数据加载中...
 
   



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

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