目录

java_方法递归调用

基本介绍

简单的说: 递归就是方法自己调用自己,每次调用时传入不同的变量.递归有助于编程者解决复杂问题,同时可以让代码变得简洁

递归执行机制1------打印问题

java 复制代码
public class Recursion01 {
    public static void main(String[] args) {
        T t = new T();
        t.test(4);
    }
}

class T {
    public void test(int n){
        if(n > 2) test(n-1);
        System.out.println("n = " + n);
    }

}


递归执行机制2------阶乘问题

java 复制代码
public class Recursion01 {
    public static void main(String[] args) {
        T t = new T();
        t.test(4);

        int res = t.factorial(5);
        System.out.println("res = " + res);
    }
}

class T {
    public void test(int n){
        if(n > 2) test(n-1);
        System.out.println("n = " + n);
    }

    public int factorial(int n) {
        if (n == 1) {
            return 1;
        } else {
            return factorial(n-1) * n;
        }
    }

}

递归重要规则

练习题------斐波那契数

java 复制代码
/*
* @Author: Marte
* @Date:   2024-10-27 15:10:05
* @Last Modified by:   Marte
* @Last Modified time: 2024-10-27 15:23:37
*/

public class RecursionExercise01 {
    public static void main(String[] args) {
        T t1 = new T();
        int n = 7;
        int res = t1.Fibonacci(n);
        System.out.println("整数"+ n + "对应的斐波那契数是 " + res); // res = 13
    }
}

class T {
    /*
请使用递归的方式求出斐波那契数 1,1,2,3,5,8,13...给你一个整数 n,求出它的值是多
思路分析
1. 当 n = 1 斐波那契数 是 1
2. 当 n = 2 斐波那契数 是 1
3. 当 n >= 3 斐波那契数 是前两个数的和
4. 这里就是一个递归的思路
*/
    public int Fibonacci(int n) {
        if(n >= 1){
            if (n == 1 || n == 2){
                return 1;
            } else {
                return Fibonacci(n-1) + Fibonacci(n-2);
            }
        } else {
            System.out.println("要求输入的n >= 1的整数");
            return -1;
        }

    }
}

练习题------猴子吃桃子问题

java 复制代码
public class RecursionExercise02 {
   public static void main(String[] args) {
       T t1 = new T();
       int res = t1.peach(0);
       if(res != -1)
           System.out.println("第一天时的桃子数量为:"+ res);
   }
}

class T {
/*    猴子吃桃子问题:有一堆桃子,猴子第一天吃了其中的一半,并再多吃了一个!
以后每天猴子都吃其中的一半,然后再多吃一个。当到第 10 天时,
想再吃时(即还没吃),发现只有 1 个桃子了。问题:最初共多少个桃子?
思路分析 逆推
1. day = 10 时 有 1 个桃子
2. day = 9 时 有 (day10 + 1) * 2 = 4
3. day = 8 时 有 (day9 + 1) * 2 = 10
4. 规律就是 前一天的桃子 = (后一天的桃子 + 1) *2//就是我们的能力
5. 递归*/
   public int peach(int day){
       if(day == 10){
           return 1;
       } else if(day >= 1 && day <= 9) {
           return (peach(day+1) + 1) * 2;
       } else {
           System.out.println("day在 1- 10");
           return -1;
       }
   }
}
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
无名之逆13 分钟前
[特殊字符] Hyperlane 框架:高性能、灵活、易用的 Rust 微服务解决方案
运维·服务器·开发语言·数据库·后端·微服务·rust
SnXJi_23 分钟前
开源赋能,双驱协同:纷析云财务与进销存软件助力企业数字化转型
java·gitee·开源·开源软件
Vitalia28 分钟前
⭐算法OJ⭐寻找最短超串【动态规划 + 状态压缩】(C++ 实现)Find the Shortest Superstring
开发语言·c++·算法·动态规划·动态压缩
eternal__day33 分钟前
第三期:深入理解 Spring Web MVC [特殊字符](数据传参+ 特殊字符处理 + 编码问题解析)
java·前端·spring·java-ee·mvc
最后一个bug37 分钟前
PCI与PCIe接口的通信架构是主从模式吗?
linux·开发语言·arm开发·stm32·嵌入式硬件
落落鱼201338 分钟前
TP6图片操作 Image::open 调用->save()方法时候报错Type is not supported
开发语言
iccb101343 分钟前
在线聊天系统中的多窗口数据同步技术解密
java·github
慕离桑1 小时前
SQL语言的物联网
开发语言·后端·golang
"_rainbow_"1 小时前
Qt添加资源文件
开发语言·qt
逸狼1 小时前
【JavaEE进阶】MyBatis(5)-MyBatis-plus
java·开发语言