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);
        }
    }
}

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

在这里插入图片描述


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);
        }
    }
}

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


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



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值