当前位置:   article > 正文

JAVA基础总结(十二) JAVA 递归详解_java递归原理

java递归原理

一、概念

1、什么是递归?

  • 所谓递归就是自己调用自己。

2、递归的原理及作用

  • 递归的原理:
    • 通过直接或者间接的形式去调用方法本身
  • 递归的作用:
    • 重复的调用方法本身,用来实现某些功能或者计算出某些数值,通常用在算法上面。

3、递归的分类

  • 递归分为两种:

    1. 直接递归:方法自身调用自己。
    2. 间接递归:A方法调用B方法,B方法调用C方法,C方法再调用A方法。

4、在使用递归时的注意事项

  1. 递归一定要有条件限定,保证递归能够停止下来,否则会形成死循环并发生栈内存溢出(StackOverflowError)。
  2. 递归中虽然限定了停止下来的条件,但是递归次数不能太多,否则也会发生栈内存溢出。
  3. 禁止构造方法递归。


二、递归的练习及扩展

1、练习:使用递归计算1-100的累加和

/**
 * 递归练习:使用递归计算1-100的累加和
 */
public class AddRecursion {
    public static void main(String[] args) {
        System.out.println(sum(100));
    }

    public static int sum(int n) {
        if (n == 1) {
            return 1;
        } else {
            return n + sum(n - 1);
        }
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

运行结果:
在这里插入图片描述
使用递归方法计算的原理图:

在这里插入图片描述


2、练习:使用递归计算10的阶乘

/**
 * 递归练习:使用递归计算10!阶乘(1*2*3*4*...*10)的值
 */
public class FactorialRecursion {
    public static void main(String[] args) {
        System.out.println(Factorial(10));
    }
    public static int Factorial(int n){
        if (n==1){
            return 1;
        }else{
          return  n*Factorial(n-1);
        }
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

运行结果:
在这里插入图片描述


阶乘扩展,是不是多少有点后悔当初没好好学数学emmmm



声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/空白诗007/article/detail/1014405
推荐阅读
相关标签
  

闽ICP备14008679号