Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 660|回复: 0

[算法学习]"斐波那契数列"的两种算法

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-11-14 00:08:32 | 显示全部楼层 |阅读模式
    “斐波那契数列”的两种算法
         
       
          
         
       
         斐波那契数列有个规律:从第三个数开始,每个数是前两个数之和,比如:
         
       
         1 1 2 3 5 8 13 21 34 55......
         
       
          
         
       
         现在通过两种方式(递归与非递归)算数列中第N个值,代码如下:
         
       
          
         
         
         
          /**
    * 斐波那契数列算法,从第三个数开始,每个数是前两个数之和:1 1 2 3 5 8 13 21 34 55
    * 求第N个数的两种算法,分递归和非递归两种
    */
          

          public
          class Fib {
          
             
          public
          static
          void main(String[] args) {
          
                     System.out.println(f(20));
          
                     System.out.println(fx(20));
          
             }
          

          
             
          //递归方式
          
             
          public
          static
          int f(
          int n) {
          
                     
          //参数合法性验证
          
                     
          if (n < 1) {
          
                             System.out.println(
          "参数必须大于1!");
          
                             System.exit(-1);
          
                     }
          
                     
          if (n == 1 || n == 2)
          return 1;
          
                     
          else
          return f(n - 1) + f(n - 2);
          
             }
          

          
             
          //非递归方式
          
             
          public
          static
          int fx(
          int n) {
          
                     
          //参数合法性验证
          
                     
          if (n < 1) {
          
                             System.out.println(
          "参数必须大于1!");
          
                             System.exit(-1);
          
                     }
          
                     
          //n为1或2时候直接返回值
          
                     
          if (n == 1 || n == 2)
          return 1;
          

          
                     
          //n>2时候循环求值
          
                     
          int res = 0;
          
                     
          int a = 1;
          
                     
          int b = 1;
          
                     
          for (
          int i = 3; i <= n; i++) {
          
                             res = a + b;
          
                             a = b;
          
                             b = res;
          
                     }
          
                     
          return res;
          
             }
          
    }
          
         
       
          
         
       
         运行结果:
         
         
         
          6765
          
    6765
          

          
    Process finished with exit code 0
          
         
       
          
         
       
         还是递归的代码简单些,不过递归总体来说是以空间换时间,速度快,耗内存。
         
       
         非递归比较省内存,速度稍微慢些。
         
        本文出自 “熔 岩” 博客,请务必保留此出处http://lavasoft.blog.51cto.com/62575/199680
       
       

       
         
         
          
          

            
          

            
          
         
       

      


    源码下载:http://file.javaxxz.com/2014/11/14/000832671.zip
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-2-25 07:52 , Processed in 0.334066 second(s), 34 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表