Java-递归--------(十)

什么是递归?

                解决具有规律性的问题时,在方法内部再次调用自身方法的一种编程方式。

何时使用递归?

                1、当需要解决的问题可以拆分成若干个小问题,大小问题的解决方式相同,方法中自

        调用自己。

                2、使用循环解决的常规问题,都可以替换为递归解决。

如何正确使用递归?

                设置有效的出口条件,可以让调用链上的每个方法都可以正确返回,避免无穷递归。

 下面的代码就属于无穷递归的一种;

在运行过程中,sumA调用sumB,sumB又来调用sumA,

两者之间来回调用,这样就进入了无穷递归

运行之后就会内存溢出(如下图)

public class Demo{
	
    public static void main(String args[]){
    	sumA();
    }  
    public static void sumA() {
    	System.out.println("这是sumA");
    	sumB();
    }
    public static void sumB() {
    	System.out.println("这是sumB");
    	sumA();
    }
}

 

 使用递归求阶乘

public class Demo{
	
    public static void main(String args[]){
    //调用阶乘的方法 求5的阶乘
    	int result=factorial(5);
    	System.out.println(result);
    }
    //求阶乘的递归方法
    public static int factorial(int a) {
    	if(a==1) {
    		return 1;
    	}
    	return a*factorial(a-1);
    }
}

 关于递归算法:我主页还有一个用递归求斐波那契数列的代码

→→→Java-使用递归求前20个斐波那契数列的数

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值