【java基础】递归详解

递归

  • A方法调用B方法,我们很容易理解!

  • 递归就是: A方法调用A方法!就是自己调用自己

  • 利用递归可以用简单的程序来解决-些复杂的问题。 它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。

  • 递归结构包括两个部分:

    • 递归头:什么时候不调用自身方法。如果没有头,将陷入死循环。
    • 递归体:什么时候需要调用自身方法。
public static void main(String[] args){
    
    
	System.out.println(f(4));
}
//递归方法
public static int f(int n){
    
    
	if (n==1){
    
    
	//把return 1 看作是一扇门,n=1就是钥匙,
	//之前由于没有钥匙,都堆在了门里,然后开门之后
	//后进的里们进,所以先出,这就构成了递归
	//上述仅是自己的理解!
	return 1;
	}else{
    
    
		return n*f(n-1);
	}
}

递归的缺点

对于一些嵌套层次深的算法,在物理上会造成内存崩溃。

おすすめ

転載: blog.csdn.net/m0_45290871/article/details/121534729