04-递归
-
A方法调用B方法,我们很容易理解
-
1 package xiaoka.method; 2 3 public class Demo05 { 4 public static void main(String[] args) { 5 Demo05 test = new Demo05(); 6 test.test(); 7 } 8 public void test(){ 9 test(); //酱紫不行,错误示范 10 } 11 }
-
利用递归可以用简单的程序来解决一些复杂的问题。它通常把一个大型的复杂问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序地代码量。递归的能力在于用有限的语句来定义对象的无限集合。
-
递归结构包括两个部分:
-
递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
-
递归体:什么时候需要调用自身方法。
1 package xiaoka.method; 2 3 public class Demo06 { 4 public static void main(String[] args) { 5 System.out.println(f(5)); 6 } 7 //1! 1 8 //2! 2*1 9 //5! 5*4*3*2*1 10 public static int f(int n){ 11 12 if (n==1){ 13 return 1; 14 }else { 15 return n*f(n-1); 16 } 17 } 18 }
-