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



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

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