| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 874 人关注过本帖
标题:Fibonacci()函数
只看楼主 加入收藏
huadiw
该用户已被删除
收藏
 问题点数:0 回复次数:3 
Fibonacci()函数
提示: 作者被禁止或删除 内容自动屏蔽
搜索更多相关主题的帖子: Fibonacci 函数 
2008-11-17 21:30
forever74
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:CC
等 级:版主
威 望:58
帖 子:1687
专家分:4253
注 册: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
快速回复:Fibonacci()函数
数据加载中...
 
   



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

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