Java入门:06.Java中的方法--进阶04

4方法递归

简而言之就是方法的自身调用。 也可以是方法组自身的调用

  • 递归类似循环,可以实现功能的反复执行。在某些(算法)环境下,比使用循环更轻松。

  • 递归的本质就是方法的不同调用,就会不同的产生栈帧压栈,栈空间有限,一个逻辑性不合理的递归会导致栈内存溢出(满了),所以递归时我们一般都会有一个结束条件。

java 复制代码
 public static void t1(){
     t1();
 }
 ​
 public static void t2(){
     t3();
 }
 public static void t3(){
     t2();
 }

递归公式:要想做a这件事,需要先做b那件事。a和b是一样的事

  • 当我们分析程序的时候,如果分析出递归公式,就可以考虑使用递归实现功能

  • 如果我们看到了一个使用递归实现的功能,应该可以分析出其对应的递归公式

  • 下面是一个使用递归完成1-100累加和的小案例:

java 复制代码
class A{
	public static void main(String[] args){
		int sum=doSum(100);
		System.out.println(sum);
	}
    //这个方法的作用是算累加和
	public static int doSum(int max){
        //按照递归公式,1-100的累加和,我不会算
        //我只能把当前值和其他数字的累加和算到一起
        //那么其他数字的累加和谁来算呢?
        //当前方法能算,我们就用当前数值100加上再次利用调用当前方法得来的99的累加和作为返回值,得                                         
          到1-100的累加和
        //第二次调用该方法时,所计算的就是99的累加和了,那么该方法也不会算
        //我只能用99加上1-98的累加和了。
        //我们就要用98作为最大值,来得到1-98的累加和
        //以此类推,当最大值为1时,我们就肯定知道,它的累加和了,就把它还给上一次调用它的方法,
        此时2+(1的累加和)就会作为2的累加和被返还到上一次的  3加上2的累加和 以此得到3的累加和传给4+(3的累加和)...
        //以此类推,这样从最底层开始,层层的累加和我们就都能够得到了
        //最后99的累加和也会被返还回来
        //我们就用100+(1-99的累加和)得到1-100的累加和,返回给主方法的调用处
		if(max==1){
			return 1;
		}
		return max+doSum(max-1);
	}
}

递归与循环的对比

  • 循环一定是一次执行完了, 再执行下一次。

  • 递归是一次执行到一半,就执行下一次。等下一次执行完, 这一次还要继续执行。

  • 递归不适合捋代码流程。只适合与递归公式碰撞。

相关推荐
yaoxin5211238 分钟前
279. Java Stream API - Stream 拼接的两种方式:concat() vs flatMap()
java·开发语言
@小码农10 分钟前
202512 电子学会 Scratch图形化编程等级考试三级真题(附答案)
服务器·开发语言·数据结构·数据库·算法
坚持学习前端日记23 分钟前
2025年的个人和学习年度总结以及未来期望
java·学习·程序人生·职场和发展·创业创新
Cosmoshhhyyy25 分钟前
《Effective Java》解读第29条:优先考虑泛型
java·开发语言
一路往蓝-Anbo27 分钟前
C语言从句柄到对象 (六) —— 继承与 HAL:父类指针访问子类数据
c语言·开发语言·stm32·嵌入式硬件·物联网
北冥有一鲲30 分钟前
A2A协议与LangChain.js实战:构建微型软件工厂
开发语言·javascript·langchain
Chen不旧37 分钟前
java基于reentrantlock/condition/queue实现阻塞队列
java·开发语言·signal·reentrantlock·await·condition
laplace01231 小时前
Part 3:模型调用、记忆管理与工具调用流程(LangChain 1.0)笔记(Markdown)
开发语言·人工智能·笔记·python·langchain·prompt
寒水馨1 小时前
com.github.oshi : oshi-core 中文文档(中英对照·API·接口·操作手册·全版本)以6.4.0为例,含Maven依赖、jar包、源码
java·后端
0和1的舞者1 小时前
SpringBoot日志框架全解析
java·学习·springboot·日志·打印·lombok