J2SE--递归调用

2024-08-26 21:32
文章标签 调用 递归 j2se

本文主要是介绍J2SE--递归调用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        前段时间在复习J2SE时候看到了“递归”和“迭代”这部分知识,之前没有很好的梳理,这次补上总结。

        一、概念理解:

        (1) 递归

      “从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?“从前有座山,山里有座庙,庙里有个老和尚,正在给小和尚讲故事呢!故事是什么呢?……””。

         这个故事永远也讲不完,因为没有递归结束条件,如果递归没有结束条件,那么就会无限递归下去。

         其实递归很简单,形式上一个递归结束条件,一个自己调用自己的方法

 

        (2)迭代

          迭代是重复一组指令,不断第根据变量的旧值推出新值,最终得到所需的解。


        二、对比

       用一个求等差数列前N项和的例子:1+2+3+4……

       对于递归:

       sum(5)

      5+sum(4)

      5+4+sum(3)

      5+4+3+sum(2)

      5+4+3+2+sum(1)

      5+4+3+2+1+sum(0)

      5+4+3+2+1+0

      5+4+3+2+1

      5+4+3+3

      5+4+6

      5+10

      15

       可以观察到,递归调用是一个先扩展后收缩的过程,即先进行递推,之后进行回归,类似于我们在软考中所学到的“分治法”,大问题化小问题,小问题解决之后再综合求解大问题。

       如图--J2SE视频举例:一定是走到最深处之后,才进行返回。

                         

 

        然而对于迭代方法:           

         0+1=1

        1+2=3

        3+3=6

        6+4=10

        10+5=15

       用计算出的结果当做新值继续计算,得到最终结果,这个过程更像是一条直线,把后面的线段拿到前面,不断地前进,没有扩张和收缩的过程。

       从如上对比中,可以看到“递归”在执行过程中,会有一个扩充再收缩的过程,很容易让人联想到化学课上的“链式反应”,不易受控制,正如概念中所提到的,递归“一个终止条件、一个自身调用”, 一旦终止条件不对,扩张过程加大,容易导致“溢出”错误,而迭代则是直线式进行,在资源上不会出现这种情况。

       而之所以会出现溢出,使用递归时每调用一次,就需要在栈上开辟一块空间,而使用迭代时,不会这样,因为仅仅是重复调用某一个过程,所以相比之下,使用迭代更加安全。

      然而,在我们使用算法过程中,像之前学习过的回溯法、分治法,都用到了递归调用,在数据结构中,树的遍历,图的搜索,也都是递归,这当然另当别论,一般情况下,能使用迭代,就少用递归。



 

 

这篇关于J2SE--递归调用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1109733

相关文章

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

SpringCloud之LoadBalancer负载均衡服务调用过程

《SpringCloud之LoadBalancer负载均衡服务调用过程》:本文主要介绍SpringCloud之LoadBalancer负载均衡服务调用过程,具有很好的参考价值,希望对大家有所帮助,... 目录前言一、LoadBalancer是什么?二、使用步骤1、启动consul2、客户端加入依赖3、以服务

Vue 调用摄像头扫描条码功能实现代码

《Vue调用摄像头扫描条码功能实现代码》本文介绍了如何使用Vue.js和jsQR库来实现调用摄像头并扫描条码的功能,通过安装依赖、获取摄像头视频流、解析条码等步骤,实现了从开始扫描到停止扫描的完整流... 目录实现步骤:代码实现1. 安装依赖2. vue 页面代码功能说明注意事项以下是一个基于 Vue.js

Jackson库进行JSON 序列化时遇到了无限递归(Infinite Recursion)的问题及解决方案

《Jackson库进行JSON序列化时遇到了无限递归(InfiniteRecursion)的问题及解决方案》使用Jackson库进行JSON序列化时遇到了无限递归(InfiniteRecursi... 目录解决方案‌1. 使用 @jsonIgnore 忽略一个方向的引用2. 使用 @JsonManagedR

讯飞webapi语音识别接口调用示例代码(python)

《讯飞webapi语音识别接口调用示例代码(python)》:本文主要介绍如何使用Python3调用讯飞WebAPI语音识别接口,重点解决了在处理语音识别结果时判断是否为最后一帧的问题,通过运行代... 目录前言一、环境二、引入库三、代码实例四、运行结果五、总结前言基于python3 讯飞webAPI语音

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

Java中将异步调用转为同步的五种实现方法

《Java中将异步调用转为同步的五种实现方法》本文介绍了将异步调用转为同步阻塞模式的五种方法:wait/notify、ReentrantLock+Condition、Future、CountDownL... 目录异步与同步的核心区别方法一:使用wait/notify + synchronized代码示例关键

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

Python调用Orator ORM进行数据库操作

《Python调用OratorORM进行数据库操作》OratorORM是一个功能丰富且灵活的PythonORM库,旨在简化数据库操作,它支持多种数据库并提供了简洁且直观的API,下面我们就... 目录Orator ORM 主要特点安装使用示例总结Orator ORM 是一个功能丰富且灵活的 python O

Java调用DeepSeek API的最佳实践及详细代码示例

《Java调用DeepSeekAPI的最佳实践及详细代码示例》:本文主要介绍如何使用Java调用DeepSeekAPI,包括获取API密钥、添加HTTP客户端依赖、创建HTTP请求、处理响应、... 目录1. 获取API密钥2. 添加HTTP客户端依赖3. 创建HTTP请求4. 处理响应5. 错误处理6.