概述
A方法调用B方法,我们很容易理解!
递归就是: A方法调用A方法,一个方法调用自身的过程。
递归的结构
递归的结构包括两个部分:
- 递归头(出口条件):什么时候不调用自身方法。如果没有,程序将陷入死循环。
- 递归体:什么时候需要调用自身方法。
引用
利用递归可以用简单的程序来解决一些复杂的问题。它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。
示例
如下,用递归求 5 的阶乘示意图(画的比较丑,凑合看~)
java中实现
package com.mJane.method;
public class Demo02 {
public static void main(String[] args) {
Demo02 jiec = new Demo02(); //创建类的一个对象,对象名 jiec
System.out.println(jiec.f(5)); // 对象名.方法名
}
/**
* f()方法没有加 static(类方法) 修饰符,不能被直接调用
* 可通过如上的方法 new 对象 的方法来调用
*/
public int f(int n){
if (n==1){
return 1;
}
return n*f(n-1);
}
}