码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 方法练习(二)


    斐波那契数列

    斐波那契数指的是这样一个数列:1、1、2、3、5、8、13、21、34、……从第三个数开始,每个数都是前两个数的和。
    使用递归求出第n个斐波那契数的值是多少

    public class Method02{
    	public static void main(String[] args) {
    	T t = new T();
    	int a =t.fibonacci(7);
    		System.out.println(a);
    }
    }
    class T{
    	public int fibonacci(int n){
    		if (n == 1||n == 2) {// 特殊情况 第1/2个数
    			return 1;
    		}
    		if (n > 2) {   
    			return fibonacci(n-1)+fibonacci(n-2);//斐波那契数列的规律,递归调用
    		}else{
    			return -1;  //除了正常的数字
    		}
    		
    	}
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20

    猴子吃桃

    有一只猴子从树上摘了n个桃,第一天吃了一半然后忍不住又吃了一个,第二天到第九天都是如此,到第10天还没吃的时候发现就一个桃子了。问当时摘了几个桃?
    由上面问题可得出
    第9天的桃子=(1+1)*2
    第8天的桃子=(第9天的桃+1)*2
    第7天的桃子=(第8天的桃+1)*2
    .以此类推
    使用递归解决得出公式
    day10=1
    day9=(day10+1)*2
    day8=(ady9+1)*2
    …
    符合递归调节
    关键代码
    if(day == 10){
    retunrn 1;
    }else if(day >= 1 && day <=9){
    retunrn (猴子吃桃方法(day+1)+1)*2;//这里的调用看作是一个成员变量,当前天数的桃=((当前天数+1)+1)*2
    }
    还是递归调用概念,当调用本方法立刻重新开一个栈,在新开的栈进行运算,如果还有调用就继续开栈,然后运算结束 依次返回继续进行当初调用后面的语句。
    代码演示

    public class Method03{
         public static void main(String[]args){
            T t = new T();
            int num = t.monkeyEating(7);//第7天桃
            System.out.println("第7天桃有"+" "+num+"个");
     
      }
    }
    class T{
        public int monkeyEating(int day){
         if(day == 10){
                 return 1;
                }else if(day >= 1 && day <= 9){
                   return (monkeyEating(day+1)+1)*2;    
                    } 
        else{
        System.out.println("请输入1-10");
        return -1;
        }
           
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22

    注意事项:当递归执行调用到最后一层时,返回的是方法运算完之后的一个值,在思想维度上要跟上。
    内存示意图
    在这里插入图片描述
    同理求出当时摘了多少桃 即第一天的桃传入实参 1 得到返回值为 1534 个桃

  • 相关阅读:
    微信小程序组件化开发
    c语言每日一练(15)
    【QT+CUDA】QT中使用cuda,QT+VS+cuda下载安装配置
    【Local/Docker/K8S/Racher】Local/Docker/K8S/Racher安装Celery并启动异步任务-20220820
    ceph 006 rbd高级特性 rbd快照 镜像克隆 rbd缓存 rbd增量备份 rbd镜像单向同步
    【SpringCloud】微服务技术栈入门8 - 黑马旅游微服务项目实战笔记
    【camera】【ISP】Lens Shading Correction镜头阴影校正
    c++-基本计算器的灵活可扩展实现
    (delphi11最新学习资料) Object Pascal 学习笔记---第10章第1节(通过引用设置属性)
    Centos7根目录扩容方法(添加一块磁盘扩容根目录)
  • 原文地址:https://blog.csdn.net/WINorYU/article/details/126808272
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号