广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java方法递归的思路详解
  • 154
分享到

Java方法递归的思路详解

2024-04-02 19:04:59 154人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录前言一、什么是方法递归二、什么场景下能用递归三、如何写出递归代码-重点总结前言 今天给老铁们回顾一下递归的思路以及方法,也是给自己的一个归纳总结。 一、什么是方法递归 所谓的方法

前言

今天给老铁们回顾一下递归的思路以及方法,也是给自己的一个归纳总结。

一、什么是方法递归

所谓的方法递归,就是在一个方法(函数)执行的内部,自己调用了自己的过程,称之为 “递归” 。

递归分为两个子过程:

  • 递过程:函数不断地调用自身,直到走到函数的终止条件,第一阶段结束。
  • 归过程:函数不断地返回的过程。

例如, 我们求 N! 起始条件: N = 1 的时候, N! 为 1. 这个起始条件相当于递归的结束条件. 递归公式: 求 N! ,

直接不好求, 可以把问题转换成 N! => N * (N-1)!

示例:递归求N的阶乘

public static void main(String[] args) {
    int n = 5;
    int ret = factor(n);
    System.out.println("ret = " + ret);
}
public static int factor(int n) {
    if (n == 1) {
        return 1;
   }
    return n * factor(n - 1); // factor 调用函数自身
}
// 执行结果
ret = 120

二、什么场景下能用递归

a.一个大问题(这个方法的功能)可以拆分成若干个子问题的解.

b.拆分后的子问题和原问题除了数据规模不同,解决思路完全相同.

c.必须存在递归的终止条件(不会无限拆分下去,一定能走到底~).

(看不懂先看下面(●ˇ∀ˇ●))

三、如何写出递归代码-重点

  • 先考虑这个函数的终止条件

比如上面的栗子:求N的阶乘。

拿求5的阶乘做例子:

在这里插入图片描述

我们把大问题(5的阶乘)一直拆分到1的时候,问题无法继续拆分下去了,这个子问题就是这个递归的最终条件。

所以我们写代码的时候,可以先把最终条件写上:

if (n == 1) {
        return 1;
   }
  • 假设这个函数已经写好了(注意这个方法的语义)

在写递归函数的时候,千万不要纠结这个函数内部是如何实现的,而是要注意这个函数有什么功能(假设这个函数别人已经写好了),我们把它当作一个黑盒子,你只是去调用这个函数罢了。

public static int factor(int n)

比如这个函数只能传入一个n,目前我们只能知道这个n是多少,而n的阶乘等于n* [(n-1)!],但是我们并不知道n-1的阶乘是多少,那么就调用这个别人写好的“黑盒子”。这个黑盒子的功能可以实现某个数的阶乘。

n * factor(n - 1) // n*黑盒子

说白了就是,把这个factor函数当作别人已经写好了,你只需要关注如何去调用这个方法去辅助你解决问题就可以了!

总结

写出递归其实=终止条件+利用黑盒子去解决剩下的问题,注意传入的参数就可以很快把递归代码写出来(●ˇ∀ˇ●)。

到此这篇关于Java 方法递归的思路详解的文章就介绍到这了,更多相关Java 递归内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java方法递归的思路详解

本文链接: https://www.lsjlt.com/news/145949.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java方法递归的思路详解
    目录前言一、什么是方法递归二、什么场景下能用递归三、如何写出递归代码-重点总结前言 今天给老铁们回顾一下递归的思路以及方法,也是给自己的一个归纳总结。 一、什么是方法递归 所谓的方法...
    99+
    2022-11-13
  • Java的递归算法详解
    目录一、介绍1、介绍2、案例二、迷宫问题三、八皇后问题四、汉诺塔问题1、问题2、思想3、代码总结一、介绍 1、介绍 递归:递归就是方法自己调用自己,每次调用时传入不同的变量。递归有助...
    99+
    2022-11-12
  • Java递归算法详解
    递归算法是一种通过调用自身来解决问题的方法。在Java中,递归算法通常有以下几个要素:1. 基本情况:递归方法必须有一个基本情况,即...
    99+
    2023-09-14
    Java
  • JavaSE递归求解汉诺塔问题的思路与方法
    目录1. 汉诺塔的介绍和玩法2. 汉诺塔问题的思路3. 用递归的代码实现 总结1. 汉诺塔的介绍和玩法 汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古...
    99+
    2022-11-13
    javase递归求解汉诺塔 用递归求解汉诺塔问题 递归实现汉诺塔问题java
  • Java递归实现菜单树的方法详解
    pom文件 <xml version="1.0" encoding="UTF-8"> <project xmlns="http://maven.apache.or...
    99+
    2022-11-13
  • Java用递归方法解决汉诺塔问题详解
    目录前言一、问题描述二、问题分析三、解决方案四、示例前言 博主之前有写过关于递归问题的思维模式: 递归的思路 下面将用这种思维模式来求解经典汉诺塔问题。 一、问题描述 汉诺塔(又称河...
    99+
    2022-11-13
  • Java方法递归的形式和常见递归算法(方法递归结合File类查找文件)
    目录方法递归方法递归的形式递归常见的算法非规律递归案例方法递归 方法递归的形式 什么是方法递归 方法直接调用自己或者间接调用自己的形式称为方法递归( recursion)。 递归做为...
    99+
    2023-02-28
    Java方法递归 java递归算法 java File类查找文件
  • Python数据结构之递归方法详解
    目录1.学习目标2.递归2.1递归的基本概念2.2递归的重要性2.3递归三原则2.4递归的应用3.递归示例3.1列表求和3.2汉诺塔(Towers of Hanoi)问题1.学习目标...
    99+
    2022-11-10
  • java词法分析器DDL递归应用详解
    目录前言intellij plugin词法解析状态迁移DDL 解析递归解析总结前言 最近大部分时间都在撸Python,其中也会涉及到将数据库表转换为Python中ORM框架的Mode...
    99+
    2022-11-13
  • Java递归算法详解(动力节点整理)
    递归算法是一种直接或者间接调用自身函数或者方法的算法。Java递归算法是基于Java语言实现的递归算法。递归算法的实质是把问题分解成规模缩小的同类问题的子问题,然后递归调用方法来表示问题的解。递归算法对解决一大类问题很有效,它可以使算法简洁...
    99+
    2023-05-31
    java 递归 ava
  • Java方法递归的形式和常见递归算法代码分析
    本篇内容介绍了“Java方法递归的形式和常见递归算法代码分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!方法递归方法递归的形式什么是方法递...
    99+
    2023-07-05
  • Java中的递归方法怎么用
    小编给大家分享一下Java中的递归方法怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!递归方法定义本身调用方法本身的现象叫做递归在这之前我们学的东西:例如St...
    99+
    2023-06-22
  • java尾部递归的使用方法
    这篇文章给大家分享的是有关java尾部递归的使用方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、说明在尾部递归中,递归调用是函数执行的最后一件事,因此编译器不需要保存函数堆栈帧。大多数编译器可以像优化迭代代...
    99+
    2023-06-15
  • Java二叉树的递归和非递归遍历方法是什么
    本篇内容主要讲解“Java二叉树的递归和非递归遍历方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java二叉树的递归和非递归遍历方法是什么”吧!前言二叉树的遍历方法分为前序遍历,中序遍...
    99+
    2023-06-30
  • Java开发深入分析讲解二叉树的递归和非递归遍历方法
    目录前言1.递归遍历2.非迭代遍历3.二叉树的统一迭代法前言 二叉树的遍历方法分为前序遍历,中序遍历,后续遍历,层序遍历。 1.递归遍历 对于递归,就不得不说递归三要素:以前序遍历...
    99+
    2022-11-13
  • Java中的递归方法示例介绍
    目录递归递归的注意事项:案例一递归求阶乘不使用递归实现阶乘使用递归实现阶乘澳大利亚不死神兔(斐波那契数列)使用数组实现使用递归实现总结递归 方法定义本身调用方法本身的现象叫做递归 在...
    99+
    2022-11-12
  • Java递归寻路实现,你真的理解了吗
    目录引使用递归计算阶乘地图创建核心完整代码总结引 看懂这张图,方法调用方法,栈开新栈,递归尾结束要回到main栈,必须一级一级返回,每一次返回都是调用整个方法,调用完成栈被释放,直至回到栈底main递归结束并能够自己画出来,理解递归的运行...
    99+
    2017-05-23
    Java递归 java实现
  • 详解Java递归实现树形结构的两种方式
    目录0、引言1、数据准备2、类型转化3、递归实现方法3.1、Java7及以下纯Java递归实现3.2、Java8及以上借助lamda表达式实现0、引言 在开发的过程中,很多业务场景需...
    99+
    2022-11-13
    Java递归实现树形结构 Java树形结构 Java递归
  • Java中方法的使用、重载与递归的详细介绍
    目录一.方法的基本使用1.什么是方法2.方法基本语法二.方法的重载1.重载的作用2.重载的使用规则三.方法的递归1.递归的概念2.递归执行过程分析3.递归练习1.按顺序打印一个数字的...
    99+
    2022-11-12
  • 利用Java递归解决“九连环”公式的方法
    这篇文章主要介绍利用Java递归解决“九连环”公式的方法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!九连环的玩法规则用一句话来概括就是:如果你想要卸掉某一环或者装上某一环,只需要保留这一环前面一环,再之前所有的环都...
    99+
    2023-06-06
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作