Java基础-算法-递归

本文深入解析了递归的概念,通过计算阶层的例子展示了递归的工作原理。递归包含递归头(定义停止条件)和递归体(调用自身)。在执行递归时,每个方法都有独立的栈空间,局部变量互不影响,但引用类型变量共享数据。递归必须设置退出条件以防止无限递归,并遵循方法调用和返回的规则。理解递归对于编程解决问题至关重要。
摘要由CSDN通过智能技术生成

什么是递归

A方法调用A方法,就是方法调用自己,用于类似的阶层的计算

递归结构包括两个部分:

递归头:什么时候不调用自身方法,如果没有头,将陷入死循环

递归体:什么时候需要调用自身方法

举例

package Demo;

public class one {
    public static void  main(String[] args){
        System.out.println(f(4));
    }
    //计算阶层
    public static int f(int a){
        if (a==1){
            return 1;
        }else {
            return a*f(a-1);
            //5*f(4)
            // f(4)又会用这个方法自己计算成4*f(3)
            //f(3)又会变成3*f(2);以此类推到f(1)
        }
    }
}

结果

24

递归规则

1、执行一个方法时,就要创建一个新的受保护的独立空间(栈)

2、方法的局部变量是独立的,不会相互影响。

3、如果方法中使用的是引用类型变量(比如数组),就会共享该引用类型的数据

4、递归必须出现退出的条件,否则就是无限递归

5、当一个方法执行完毕,或者遇到return,就会返回,遵守谁调用,就将结果返回给谁,同时当方法执行完毕或者返回时,该方法也就执行完毕

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值