【Java递归】一篇文章带你了解,什么是递归 ,递归的特点,递归应用场景,递归练习题

news2024/11/25 6:43:38

在这里插入图片描述

博主:東方幻想郷
专栏分类:Java | 从入门到入坟

Java递归

  • ⭐ 递归的定义
  • ⭐ 递归的特点
  • ⭐ 递归应用场景
  • ⭐ 简单例子
  • ⭐ 递归练习题
    • 🌌 练习题模板
    • 🏴‍☠️ 练习题答案:

⭐ 递归的定义

🌟递归是一种在方法通过调用自身来解决某些问题的技术,它可以将一些问题,分为更小,更细类似的子问题,逐步解决,直到问题被简化到某个基本情况,最后可以直接拿到答案。

⭐ 递归的特点

  1. 递归是一种函数调用自身的方法
  2. 递归函数中,必须要有一个停止递归的条件,否则将会一直循环(return)
  3. 递归可以使代码更加简洁

⭐ 递归应用场景

  1. 一些树,图,需要使用到递归函数,遍历整个数据结构
  2. 数学问题:例如求阶乘、斐波那契数列等

⭐ 简单例子

我们来看一个非常简单的例子,递归求解1~n的和

在递归算法中,基线条件是指当递归函数调用到一定深度时,就不再递归调用,而是直接返回结果的情况。基线条件是递归算法的终止条件,如果没有基线条件,递归将会无限进行下去,最终导致栈溢出错误。

public class RecursionExample {
    public static void main(String[] args) {
        int n = 10;
        int sum = sum(n);
        System.out.println("1~" + n + "的和为:" + sum);
    }

 public static int sum(int n) {
        if (n == 1) {  // 基线条件
            return 1;
        } else {  // 递归条件
            return n + sum(n-1);
        }
    }
}

★ 这个程序的输出结果为:

1~10的和为:55

在main方法中,我们定义了n的值为10,然后调用了sum方法,传入了10作为参数。
在sum方法中,我们检查传入的n是否等于1,如果等于1,则返回1,这就是我们所说的基线条件(也就是递归结束的条件).
如果n不等于1,就执行else语句中的代码,也就是返回n加上调用sum(n-1)的结果。这就是我们所说的递归条件(也就是递归调用的条件).
sum(n-1)会再次调用sum方法,传入n-1作为参数,然后检查n-1是否等于1,如果等于1,返回1,否则再次执行递归条件.
依此类推,直到n等于1时,递归结束,开始回溯计算所有的结果.
最后返回的结果就是1~n的和.

⭐ 递归练习题

🌌 练习题模板

* 如题:请编写一个递归函数,计算一个整数的阶乘。

* 例如:输入 5,输出 120(5! = 5 × 4 × 3 × 2 × 1 = 120)

// 练习代码
public class Factorial {
    public static int factorial(int n) {
		// 请答题
    }

    public static void main(String[] args) {
        int n = 5;
        System.out.println(n + "! = " + factorial(n));
    }
}

🏴‍☠️ 练习题答案:

public class Factorial {
    public static int factorial(int n) {
        if (n == 0 || n == 1) { // 基线条件
            return 1;
        } else {
            return n * factorial(n - 1); // 递归条件
        }
    }

    public static void main(String[] args) {
        int n = 5;
        System.out.println(n + "! = " + factorial(n));
    }
}

当前计算阶乘的 factorial 方法中,如果n == 0 或 n == 1,则返回为 1
若基线条件不成立,则会走递归条件,并开始计算n的阶乘
若当n = 5 时,return为
5 * 4 * 3 * 2 * 1

🌟 总的一句话概括:递归就是自己调用自己,完成数据的实现过程,拿到返回结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/559699.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用echocollect e将西门子PLC数据转发至SQL Server数据库

一 背景 随着工业4.0和工业大数据的发展,越来越多的制造型企业开始应用大型数据库来收集和分析数据,以辅助生产运营的决策。在制造工厂中实时收集和分析设备数据能够优化生产流程、减少停机时间并提高效率。然而,这些必要的设备数据通常被“…

在线教育平台小程序,打造高效学习新模式

随着科技的不断发展和互联网的普及,线上教育已经成为了现代人们获取知识、提升自我、实现梦想的重要途径。伴随而来的是线上教育平台的极度竞争。如何才能在这个竞争激烈的市场中脱颖而出?构建一个高效的、符合学生需求的线上教育课堂小程序非常关键。 …

性能测试重要知识与TPS上不去原因分析,测试进阶之路卷起来...

目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 常见性能测试术语…

阿里P7晒出工资条,看完扎心了……

前几天,有位老铁私信我,说看到某95后学弟晒出阿里P7的工资单,他是真酸了…想狠补下技术,努力冲一把大厂。 为了帮到他,也为了大家能在最短的时间内做面试复习,我把软件测试面试系列都汇总在这一篇文章了。 …

基于OpenCV和PyQt5的跳绳计数器应用程序

基于OpenCV和PyQt5的跳绳计数器应用程序 介绍 本文将介绍一个基于OpenCV和PyQt5的跳绳计数器应用程序。该程序可以使用计算机摄像头来检测跳绳动作,并计算跳绳次数。本文将介绍程序的实现方法和实现细节,包括背景减除算法和轮廓检测算法的使用。 背景…

Linux(云计算)期末复习资料

1:linux概述 ​ Linux是一种自由、开放源代码的操作系统,它最初由芬兰的Linus Torvalds在1991年开发,目前已经成为世界上最流行的操作系统之一。Linux操作系统的特点是免费、稳定、安全、可定制、可移植性强、支持多任务、多用户等。 2&…

[VRTK4.0]安装VRTKv4Tilia软件包导入程序

学习目标: 演示如何从Unitv资源商店安装VRTKv4Tilia包导入器,以轻松访问VRTKv4Tilia包,这些包为构建XR体验提供了各种有用的功能. 简述: 推荐使用2022.2.11F1以上版本来进行VRTK使用,我们可以从Unity资产商店导入Tilia包管理器&am…

Windows和Kali上使用proxychains代理流量

Windows和Kali上使用proxychains代理流量 PS. 本文演示都是在kali进行的,如有出入还请联系我哦1. Linux(Debian)1.1. 检查一下是否有proxychains1.2 修改config文件 2. Linux(Debian)安装proxychians43. Windows3.1 下载3.2 配置 4. Windows下的配置5. 测试 PS. 写这…

你知道黑客是什么样?

1 前言 现代人的生活离不开互联网,提到互联网人们总会想到一个词,那就是黑客。对于黑客大家对他们的了解却只局限于电影、电视中他们“无处不在”的可怕和他们“翻手为云覆手为雨”的技术中。但真正的黑客到底是什么? 2 什么是黑客 笔挺的…

【STL模版库】模拟实现list类模版 {深度剖析list迭代器,实现list深拷贝}

一、核心结构 template <class T> struct list_node{ //[1]T _data; //[2]list_node *_next; //指向下一个节点list_node *_prev; //指向前一个节点list_node(const T &val T()):_data(val),_next(nullptr),_prev(nullptr){} };template <class T> class Myl…

截图自动添加水印(macOS/windows)

文章目录 1. 截图自动加水印1.1. windows1.2. macOS 2. 对已有图像批量加水印2.1 windows2.2 macOS 1. 截图自动加水印 1.1. windows 直接看这篇文章&#xff0c;一键截图自动生成水印/自动签名主要就是使用一个叫 SPX 的软件 1.2. macOS 其实apple的操作系统&#xff0c;i…

7、行为模式-观察者模式

一、观察者模式 当对象间存在一对多关系时&#xff0c;则使用观察者模式&#xff08;Observer Pattern&#xff09;。比如&#xff0c;当一个对象被修改时&#xff0c;则会自动通知依赖它的对象。观察者模式属于行为型模式。 介绍 意图&#xff1a;定义对象间的一种一对多的…

第十章:C语言的调试

很多小伙伴刚开始听到C语言的调试&#xff0c;这是个啥&#xff0c;表示很怀疑&#xff0c;敲代码不就是直接就是干嘛&#xff0c;结果很多小白们&#xff0c;一运行错误多的数都数不过来。就开始这改改&#xff0c;那删删&#xff0c;莫名奇妙就运行成功了。到最后都不知道到底…

WEB自动化测试,一定得掌握的8个核心知识点

​ 编辑 写在前面 使用 cypress 进行端对端测试&#xff0c;和其他的一些框架有一个显著不同的地方&#xff0c;它使用 JavaScript 作为编程语言。 传统主流的 selenium 框架是支持多语言的&#xff0c;大多数 QA 会的 python 和 Java 语言都可以编写 selenium 代码&#xff0…

Android逆向之雷速体育(360加固)

本教程仅限于学术探讨&#xff0c;也没有专门针对某个网站而编写&#xff0c;禁止用于非法用途、商业活动等&#xff0c;否则后果自负。如有侵权&#xff0c;请告知删除&#xff0c;谢谢&#xff01; 目录 一、攻克难点 二、分析接口 三、结束 一、攻克难点 本期app难点&am…

2023远程控制软件排行榜

对远程控制软件的排名可能是主观的&#xff0c;因为它取决于个人的需求和偏好。 但是&#xff0c;这里列出了因其功能和性能而广受认可的流行远程控制软件&#xff1a; TeamViewer TeamViewer 是一款成熟的远程控制软件&#xff0c;以其易用性和广泛的功能而闻名。 它支持远程…

君子签电子签章助推企业实现印章“集中统一管控”和“分级分权管理”

对于中大型企业来说&#xff0c;印章管理一直以来都是个“老大难”问题。 在中大型企业&#xff0c;印章数量多&#xff0c;大多分散在各个分/子公司的各个部门&#xff0c;企业印章无法统一进行有效管理。印章分散各地&#xff0c;异地分/子公司跨区域盖章难&#xff1b;分/子…

java servlet 二手物品交易平台Myeclipse开发mysql数据库web结构jsp编程计算机网页项目

一、源码特点 java servlet 二手物品交易平台是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助 系统采用 serlvetdaobean 模式开发 &#xff0c;系统具有完整的源代码和数据 库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,My…

Allure在本地不安装allure服务的情况下打开Allure Html报告

前言 我们使用pytestallure生成Allure测试报告后&#xff0c;需要发给领导查看报告的详细信息。此时我们通过将allure生成的html报告压缩成压缩包后发送给领导&#xff0c;但是领导电脑由于没有安装Allure服务&#xff0c;打开会全部显示“Loading”&#xff0c; 无法查看到报…

信创办公–基于WPS的PPT最佳实践系列 (插入表格或图标)

信创办公–基于WPS的PPT最佳实践系列 &#xff08;插入图表或图标&#xff09; 目录 项目背景操作步骤1、插入表格2、实现放映功能 项目背景 当表格数据过大时&#xff0c;将其复制粘贴到PPT上时会显得插入的表格内容小、拥挤&#xff0c;使PPT看起来不美观。这个问题我们可以…