Java开发 - 递归

简介: Java开发 - 递归

目录


前言

什么是递归

递归不得不知的经典案例:斐波那契数列

递归注意点

SOF和OOM

结语


前言


在讲到二叉树之前,一定要先把递归给讲了,只有先把基础学好了,才可以让学习的这棵二叉树更完整,更稳固一些。所以接下来,我会用代码和文字把递归的思想传递给大家,希望大家可以学到自己感兴趣的东西。


什么是递归


递归是一种思想,再变成上体现为方法的自调用。


举个例子说明:

实现某个数字的阶乘
1! = 1
2! = 1 * 2
3! = 1 * 2 * 3
4! = 1 * 2 * 3 * 4
5! = 1 * 2 * 3 * 4 * 5
6! = 1 * 2 * 3 * 4 * 5 * 6

我们最终要做的就是写一个方法,返回一个值:

public static int fun(int n) {
    return ......
}

我们需要考虑下方法块中要怎么写,观察阶乘,我们发现:

1! = 1
2! = 1! * 2
3! = 2! * 3
4! = 3! * 4
5! = 4! * 5
6! = 5! * 6

我好像发现了什么,如果我要获得n的阶乘,那是不是可以用n-1的阶乘乘以n?n-1的阶乘呢?是n-2的阶乘乘以n-1,依此类推。


方法块内,我们可以这样写:

public static int fun(int n) {
    return fun(n - 1) * n;
}

fun(n - 1)就是n-1的阶乘,这就形成了递归,然后一直递归下去。但是有个问题,这里没有考虑n=1的情况,最终会出现负数,就没有了出口,这也是递归最重要的一点,一定要有出口,否则就是死循环。所以应该这么写:

public static int fun(int n) {
    if (n == 1)
        return 1;
    return fun(n - 1) * n;
}

这样,一个求阶乘的方法就写好了,你以为很难?其实就这么简单,用事实验证了:越是难的东西越是需要简单来做,简单到你不相信这就是答案。


递归不得不知的经典案例:斐波那契数列


斐波那契数列指的是这样一个数列:1,1,2,3,5,8,13,21,34,55,89......


这个数列从第3项开始,每一项都等于前两项之和。


假如我要求第50位的数字,该怎么求?有上面的案例,不知道大家能不能自己写出来呢?


写不出来没关系,我将带领大家一起来解题,请大家跟上我的思路,我们开始。


我们先写一个方法体出来:

public static int fun(int n) {
    return ......
}

方便起见,我们就用上面的方法体,因为我要得到多少位的数字我只需要输入这个数,方法就会把这一位的数字返回给我。


上面文字已经说明:这个数列从第3项开始,每一项都等于前两项之和


那么规律就已经出现了,我们可以假设:


fun(50) = fun(49) + fun(48)


fun(49) = fun(48) + fun(47)


fun(48) = fun(47) + fun(46)


......


这里递归已经开始了,我们可以尝试着写一下这个方法块中的内容了:

public static int fun(int n) {
    return fun(n - 1) + fun(n - 2);
}

你可能已经发现了问题,和前面一样的问题:没有考虑n=1的情况,所以就没有了出口。没错,但这里还要考虑n=2的情况 ,因为是从第三位开始数列才成立。


所以需要像上面那样,通过判断1,2给方法留出口:

public static int fun(int n) {
    if (n == 1 || n == 2)
        return 1;
    return fun(n - 1) + fun(n - 2);
}


递归注意点


其实我们上面已经说到了一些注意点了,不知道大家能不能说下来?


没记住的也没关系,跟着博主一起看:


递归必须有出口,否则会导致栈内存溢出SOF(StackOverflowError);

递归是有深度的,若是深度太深,也会导致栈内存溢出SOF;

关于栈:当调用一个方法时,会在栈上为这个方法分配属于这个栈帧的内存,哪个方法的栈帧则用来保存属于哪个栈帧的局部变量。


局部变量包括:方法参数,方法内声明的一些基本变量。方法结束时,栈帧上的内存才会清除。但是栈的内存并不是无限分配的,所以当出现递归深度太深的时候会导致栈内存溢出。


SOF和OOM


SOF: statckOverFlowError   栈内存溢出

OOM: OutOfMemoryError  堆内存溢出

内存溢出指的是剩余内存不足以分配给请求的资源,此时就出现了内存溢出。可能的原因是:


创建大对象

内存泄漏的不断累积。内存泄漏累积到一定程度,会出现堆内存溢出

内存泄漏指的是分配出去的内存因为一些原因无法回收,此现象就叫内存泄漏。


内存泄漏和内存溢出的关系:

内存泄漏累积到一定程序才会造成内存溢出,并不是内存泄漏一旦出现,则立即出现内存溢出

出现内存溢出并不一定是由于内存泄漏造成的,还可能是因为创建了大对象。


结语


到这里,递归就讲完了,有不明白的小伙伴可以留言一起讨论,下一篇,我们二叉树见。

目录
相关文章
|
1月前
|
Java API Maven
如何使用Java开发抖音API接口?
在数字化时代,社交媒体平台如抖音成为生活的重要部分。本文详细介绍了如何用Java开发抖音API接口,从创建开发者账号、申请API权限、准备开发环境,到编写代码、测试运行及注意事项,全面覆盖了整个开发流程。
108 10
|
29天前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
19天前
|
Java 开发者 微服务
Spring Boot 入门:简化 Java Web 开发的强大工具
Spring Boot 是一个开源的 Java 基础框架,用于创建独立、生产级别的基于Spring框架的应用程序。它旨在简化Spring应用的初始搭建以及开发过程。
38 6
Spring Boot 入门:简化 Java Web 开发的强大工具
|
6天前
|
存储 JavaScript 前端开发
基于 SpringBoot 和 Vue 开发校园点餐订餐外卖跑腿Java源码
一个非常实用的校园外卖系统,基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化,提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合,但并不是一个完全分离的项目。 前端视图通过JS的方式引入了Vue和Element UI,既能利用Vue的快速开发优势,
52 13
|
11天前
|
算法 Java API
如何使用Java开发获得淘宝商品描述API接口?
本文详细介绍如何使用Java开发调用淘宝商品描述API接口,涵盖从注册淘宝开放平台账号、阅读平台规则、创建应用并申请接口权限,到安装开发工具、配置开发环境、获取访问令牌,以及具体的Java代码实现和注意事项。通过遵循这些步骤,开发者可以高效地获取商品详情、描述及图片等信息,为项目和业务增添价值。
44 10
|
5天前
|
前端开发 Java 测试技术
java日常开发中如何写出优雅的好维护的代码
代码可读性太差,实际是给团队后续开发中埋坑,优化在平时,没有那个团队会说我专门给你一个月来优化之前的代码,所以在日常开发中就要多注意可读性问题,不要写出几天之后自己都看不懂的代码。
40 2
|
14天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
1月前
|
开发框架 Java 关系型数据库
Java哪个框架适合开发API接口?
在快速发展的软件开发领域,API接口连接了不同的系统和服务。Java作为成熟的编程语言,其生态系统中出现了许多API开发框架。Magic-API因其独特优势和强大功能,成为Java开发者优选的API开发框架。本文将从核心优势、实际应用价值及未来展望等方面,深入探讨Magic-API为何值得选择。
42 2
|
1月前
|
监控 前端开发 Java
【技术开发】接口管理平台要用什么技术栈?推荐:Java+Vue3+Docker+MySQL
该文档介绍了基于Java后端和Vue3前端构建的管理系统的技术栈及功能模块,涵盖管理后台的访问、登录、首页概览、API接口管理、接口权限设置、接口监控、计费管理、账号管理、应用管理、数据库配置、站点配置及管理员个人设置等内容,并提供了访问地址及操作指南。
|
1月前
|
IDE Java 编译器
开发 Java 程序一定要安装 JDK 吗
开发Java程序通常需要安装JDK(Java Development Kit),因为它包含了编译、运行和调试Java程序所需的各种工具和环境。不过,某些集成开发环境(IDE)可能内置了JDK,或可使用在线Java编辑器,无需单独安装。
64 1