标题:Fibonacci()函数
只看楼主
huadiw
该用户已被删除
 问题点数:0 回复次数:3 
Fibonacci()函数
提示: 作者被禁止或删除 内容自动屏蔽
搜索更多相关主题的帖子: Fibonacci 函数 
2008-11-17 21:30
forever74
Rank: 12Rank: 12Rank: 12
来 自:CC
等 级:贵宾
威 望:49
帖 子:1636
专家分:3940
注 册:2007-12-27
得分:0 
long Fibonacci(int n)
{
  long a=1,b=1,c;
  int i;
  if(n<3)return a;
  else
    for(i=3;i<=n;i++)
    {c=a+b;a=b;b=c;}
  return c;
}

对宇宙最严谨的描述应该就是宇宙其实是不严谨的
2008-11-17 22:03
huadiw
该用户已被删除
得分:0 
提示: 作者被禁止或删除 内容自动屏蔽
2008-11-17 22:15
TangC
Rank: 1
等 级:新手上路
帖 子:22
专家分:0
注 册:2008-11-17
得分:0 
这是C++编程思想中的一个例程经过改进后的函数,主要特点是效率高:
unsigned long Fibonacci(int n)
{
    /*为了效率,牺牲一点内存,因为第48个数已经超出了unsigned long 数据类型的最大值,所以用47就可以了。*/
    static unsigned long f[47]={1,1};
    static int k=2;/*记住已经产生了多少个数*/
    if(n<1 || n>47) return 0;  /*返回0表示参数不正确,序列中不存在0值*/
    while(k<n)
    {
        /*对于已经算过的数,不会重新计算浪费时间了,所以效率非常高*/
        f[k] = f[k-1] + f[k-2];
        ++k;
    }
    return f[n-1];
}
2008-11-17 22:49



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-244857-1-1.html




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

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