| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1937 人关注过本帖
标题:关于Fibonacci数列超时问题,求解答
只看楼主 加入收藏
SmallSeven
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-17
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:6 
关于Fibonacci数列超时问题,求解答
#include<stdio.h>
int main()
{   int n ;
    int z;
int Fibonacci(int n);
    while(scanf("%d",&n)!=EOF)
    {
         z=Fibonacci(n);
         printf("%d",z);
    }
    return 0;
}

int Fibonacci(int n)
{
   
    if(n==1||n==2) return 1;
    else
    return (Fibonacci(n-1)+Fibonacci(n-2));
   
   
}
这是代码,Time Limit: 1000 mSec    Memory Limit : 32768 KB

提交系统提示超时,请问怎么解!!
搜索更多相关主题的帖子: Memory return 
2016-05-19 10:15
SmallSeven
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-17
收藏
得分:0 
来位大神帮帮忙!!
2016-05-19 10:15
SmallSeven
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-17
收藏
得分:0 
2016-05-19 10:29
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:10 
用循环试试

程序代码:
#include<stdio.h>
int main()
{
    int n;
    int z;
    int Fibonacci(int n);
    while (scanf("%d", &n) != EOF)
    {
        z = Fibonacci(n);
        printf("%d", z);
    }
    return 0;
}

int Fibonacci(int n)
{
    int i = 0,a = 0,b = 1,c = 0;
    if (n <= 1) {

        return n;

    }
    else {

        for (i = 2; i <= n; i++) {

            c = a + b;

            a = b;

            b = c;

        }

        return c;

    }



}
2016-05-19 10:32
SmallSeven
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2016-5-17
收藏
得分:0 
回复 4楼 grmmylbs
这个提交直接是wrong answer
2016-05-19 11:38
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:5 
以下是引用SmallSeven在2016-5-19 11:38:59的发言:

这个提交直接是wrong answer
你不肯给出题目要求,别人只能按你源代码的意图修改。
所以不是别人的代码有错,而是你的代码即使在不超时的情况下也是“wrong answer”
2016-05-20 08:47
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:5 
假如你的ACM支持标准的C语言,可以试试如下代码
程序代码:
#include <stdio.h>

int Fibonacci( unsigned n );

int main( void )
{
    for( unsigned n; scanf("%u",&n)==1; )
    {
        unsigned r = Fibonacci( n );
        printf( "%u\n", r );
    }
    return 0;
}

int Fibonacci( unsigned n )
{
    unsigned a=1, b=0;
    for( unsigned i=0; i!=n; ++i )
    {
        b = a + b;
        a = b - a;
    }
    return b;
}

2016-05-20 08:54
快速回复:关于Fibonacci数列超时问题,求解答
数据加载中...
 
   



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

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