当前位置: 首页 > news >正文

【Java实战】——手撕斐波那契数列

在这里插入图片描述

🎁个人主页:User_芊芊君子
🎉欢迎大家点赞👍评论📝收藏⭐文章
🔍系列专栏:【Java】内容概括

在这里插入图片描述
在这里插入图片描述

这里写目录标题

  • 1.什么是斐波那契数列?
  • 2.代码实现
    • 2.1 递归实现
    • 2.2 迭代实现
  • 3.执行结果

1.什么是斐波那契数列?

斐波那契数列(Fibonacci sequence),又称黄金分割数列 [1],因数学家莱昂纳多·斐波那契(Leonardo Fibonacci)以兔子繁殖为例子而引入,故又称“兔子数列”,其数值为:0、1、1、2、3、5、8、13、21、34……在数学上,这一数列以如下递推的方法定义:F(0)=0,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)。

这个数列从第3项开始 ,每一项都等于前两项之和

2.代码实现

2.1 递归实现

递归是一种直接或间接调用自身的编程技术。根据斐波那契数列的定义,我们可以很容易地使用递归方法来实现。

public class Test {
    public static int fib(int n) {
        if (n == 1) {
            return 0;
        }
        if (n == 2) {
            return 1;
        }
        int tmp = fib(n - 1) + fib(n - 2);
        return tmp;
    }
    public static void main(String[] args) {
        System.out.println(fib(1));
        System.out.println(fib(2));
        System.out.println(fib(3));
        System.out.println(fib(4));
        System.out.println(fib(5));
        System.out.println(fib(6));
    }
}

递归实现的优缺点:

  • 优点:代码简洁直观,符合斐波那契数列的数学定义,易于理解。

  • 缺点:存在大量的重复计算,时间复杂度较高(约为 O(2^n)),当 n 较大时,程序运行效率极低,甚至可能导致栈溢出错误。

2.2 迭代实现

迭代是通过循环的方式,逐步计算出每一项的值。相比于递归,迭代方式可以避免重复计算,提高效率。

public class Test {
    public static int fib(int n){
        if(n == 1){
            return 0;
        }
        if(n == 2){
            return 1;
        }
        int f1 = 0;
        int f2 = 1;
        int f3 = 0;
        for (int i = 3; i <= n; i++) {
            f3 = f1 + f2;
            f1 = f2;
            f2 = f3;
        }
        return f3;
    }
    public static void main(String[] args) {
        System.out.println(fib(1));
        System.out.println(fib(2));
        System.out.println(fib(3));
        System.out.println(fib(4));
        System.out.println(fib(5));
        System.out.println(fib(6));
    }
}

迭代实现的优缺点:

  • 优点:时间复杂度为 O(n),避免了递归的重复计算,效率更高,不会出现栈溢出问题。

  • 缺点:代码相对递归方式稍显复杂,理解起来可能需要更多时间。

3.执行结果

在这里插入图片描述
【总结】

  • 本文介绍了斐波那契数列的基本概念,并通过Java语言展示了两种不同的实现方式:递归和迭代实现。每种方式都有其特点和适用场景
  • 在实际编程中,我们可以根据具体需求选择合适的实现方式,以达到最优的性能和效果。
  • 希望通过本文的介绍,你对斐波那契数列及其Java实现有了更深入的理解和掌握!

在这里插入图片描述

相关文章:

  • 成都国际数字影像产业园:以产业生态优势,驱动影像业务腾飞
  • PM2 完全指南:Node.js 应用后台启动、关闭与重启详解
  • ONVIF/RTSP/RTMP协议EasyCVR视频汇聚平台RTMP协议配置全攻略 | 直播推流实战教程
  • 蓝桥杯赛前题
  • VectorBT量化入门系列:第五章 VectorBT性能评估与分析
  • zerotier安装在旁路由实现异地局域网互访的设置方法
  • P8754 [蓝桥杯 2021 省 AB2] 完全平方数
  • 蓝桥杯比赛 python程序设计——封闭图形个数
  • 使用Lombok的@Slf4j和idea构建:找不到log符号-解决
  • ARP代理
  • 微硕WINSOK高性能MOS管WSD30L40DN33在PD快充中的应用
  • JVM 之 String 引用机制解析:常量池、堆内存与 intern 方法
  • Windows 下搭建 Git 本地服务器并进行开发
  • Dify问题记录 (一)
  • 计算机视觉图像特征提取入门:Harris角点与SIFT算法
  • ctfshow WEB web9
  • 调用阿里云API实现身份证文字识别
  • 基于3d相机的点云物体检测与路径规划
  • Node.js 开发的简单 Web 服务器代码
  • 10分钟做了一个投资回报计算器,欢迎大家使用
  • 北京商城网站开发公司/seo网络优化专员
  • 企业做优化好还是超级网站好/湖南今日新闻最新头条
  • 网站制作上海/百度推广助手客户端
  • 光谷网站开发/快速排名优化推广手机
  • wordpress函数冲突/sem和seo是什么
  • 这几年做哪些网站能致富/长沙百度seo代理