【JavaSE】/*基于Java语言的递归运算*/

简介: 【JavaSE】/*基于Java语言的递归运算*/

hello,进来的小伙伴们,你们好呐!✨

🍊系列专栏:【JavaSE】🍱

🍎本篇内容:JavaSE部分的递归运算详解!(对准知识点阅读喔!)

🍮作者简介:一名大二即将大三的编程小白,我很平凡,学会努力!

🍻码云存放仓库gitee:https://gitee.com/king-zhou-of-java/java-se.git

✈️✈️正文开始:

🍏递归定义:一个方法在执行过程中调用自身, 就称为 "递归"。

🍎递归的必要条件:
1. 将原问题划分成其子问题,注意:子问题必须要与原问题的解法相同。
2. 递归出口。


一、实例演示:递归求N的阶乘

   public class fac {

       public static int factorial(int x){

           if(x<2){

               return 1;

           }

           else{

              return x * factorial(x-1);//递归调用本身

           }

       }

       public static void main(String[] args) {

           Scanner sc = new Scanner(System.in);

           int n = sc.nextInt();

           System.out.println(factorial(n));

       }

   }

🍔递归过程分析:

   🍖🍖本题假设我们想求解5的阶乘,我们可以看到我们从main函数里面输入一个数N,这里我们输入5,随即在我们的功能函数factorial接收到参数5,接着因为if里面的条件是x<2,不满足,所以执行我们的else里面的语句,我们发现是return x * factorial(x-1);我们输入的是5,所以即 return 5   *factorial(4);同理我们调用了本身这个factorial函数,传进去的参数是4,接着继续……,直到我们的参数变成1<2,那么这时递归的  “递” ,结束,开始我们的 “归”。🛥️🛥️

   // 执行结果

   函数开始, n = 5

   函数开始, n = 4

   函数开始, n = 3

   函数开始, n = 2

   函数开始, n = 1

   函数结束, n = 1 ret = 1

   函数结束, n = 2 ret = 2

   函数结束, n = 3 ret = 6

   函数结束, n = 4 ret = 24

   函数结束, n = 5 ret = 120

   ret = 120

🍶🍶运行结果:

aa84e91ee535421abf6831be889e80ad.png

二、 递归调用练习

🍓🍓一、递归求1+2+3+……10的和

   public class result {

       public static int fun(int n){

           if(n==1){

               return 1;

           }

           return n+fun(n-1);

       }

       public static void main(String[] args) {

           Scanner scanner  = new Scanner(System.in);

           int n = scanner.nextInt();

           System.out.println(fun(n));

       }

   }

🍇🍇递归的核心思想就是我们的递归体应该如何设计,本题我们想得到1+……10的和,来看我们的递归体如何设计的!

🍨运行结果:

95f3e5dca8c24d179cc37374acd891e7.png

🍊二、顺序打印一个数字的每一位

🍨问题分析:比如我们想打印1234的每一位,那么打印出来应该就是1 2 3 4那么首先就是如何判断我们输入的数字是几位数,看下面的功能代码部分,设计非常的巧妙,通过是否n>9,是->我们递归调用本身传参数 “n/10”,打印的结果就是  n%10  这样肯定得到的就是我们的每一位数字!⛵⛵

   public class print {

       public static void fun(int n){

           if(n>9){

               fun(n/10);

           }

           System.out.print(n%10+" ");

       }

       public static void main(String[] args) {

           Scanner sc = new Scanner(System.in);

           int n = sc.nextInt();

           fun(n);

       }

   }

🍬🍬运行结果:

63bd26a4efac46a9b3d2e5c3c5054336.png

🍮 三、返回一个数组成本身的数字之和

比如我们输入1234,输出就是1+2+3+4=10。

🍖🍖函数实现:

   public class sum {

       public static int sumd(int num) {

           if (num < 10)

               return num;

           return num % 10 + sumd(num / 10);

       }

       public static void main(String[] args) {

           Scanner sc= new Scanner(System.in);

           int n = sc.nextInt();

           System.out.println(sumd(n));

       }

   }

🍓🍓运行结果:

5336858523764227921bf9d8ea1f859c.png

🛩️四、求解汉诺塔问题

✨定义:汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。🌯🌯

⛵⛵代码实现:

   public class Hanio {

       public static void han(int n,char pos1,char pos2,char pos3){

           if(n==1){

               move(pos1,pos3);

               return;

           }

           han(n-1,pos1,pos3,pos2);

           move(pos1,pos3);

           han(n-1,pos2,pos1,pos3);

       }

       public static void move(char pos1,char pos2){

   

           System.out.println(pos1+"->"+pos2);

       }

       public static void main(String[] args) {

   

           han(3,'A','B','C');

       }

   }

⛴️⛴️代码解读:通过定义我们可以了解到每次只能移动一个盘子,并且小盘子要放在大盘子上面,那么这里我们有A B C,三个圆柱,我们可以将其依次理解为:初始位置   跳板位置  目标位置,我们看函数部分,如果只有一个盘子我们直接从A->C 只需移动一步便可,那么>1的情况,这里我们假设要移动三个盘子,通过画图我们可以发现首先要将2个盘子移动到B圆柱再借助A移动到C盘,那么这里的第一次调用 han(n-1,pos1,pos3,pos2);我们便可以理解,下次递归将(n-1)作为盘子个数,pos1就是我们的起始位置,pos3就是我们的跳板位置,pos2就是我们的目标位置,因为首先我们将(n-1)个盘子放在了B(pos2)上,调用结束后,执行我们的move函数,输出我们这次的移动轨迹,下次调用就是han(n-1,pos2,pos1,pos3);同理,这个时候pos2就是我们的起始位置,pos1变成我们的跳板位置,最后pos3是我们的目标位置。🍱🍱

   🍇🍇运行结果:(我们可以自己画图尝试一下看这个结果是否正确)

37a2e6039ba74123aa8dc309ae670546.png

相关文章
|
2月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
96 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
1月前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
4月前
|
Java Maven
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
该博客文章介绍了如何使用Java Swing中的JFrame创建一个窗体来收集用户输入的内容,并提供了详细的实现步骤和完整代码示例。
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
|
1月前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
55 4
|
2月前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
63 3
|
2月前
|
移动开发 Java 大数据
深入探索Java语言的核心优势与现代应用实践
【10月更文挑战第10天】深入探索Java语言的核心优势与现代应用实践
98 4
|
3月前
|
Java
java基础(11)函数重载以及函数递归求和
Java支持函数重载,即在同一个类中可以声明多个同名方法,只要它们的参数类型和个数不同。函数重载与修饰符、返回值无关,但与参数的类型、个数、顺序有关。此外,文中还展示了如何使用递归方法`sum`来计算两个数之间的和,递归的终止条件是当第一个参数大于第二个参数时。
35 1
java基础(11)函数重载以及函数递归求和
|
2月前
|
存储 Java 数据安全/隐私保护
Java中的域,什么是域?计算机语言中的域是什么?(有代码实例)
文章解释了Java中域的概念,包括实例域、静态域、常量域和局部域,以及它们的特点和使用场景。
87 2
|
2月前
|
Java 数据安全/隐私保护 C++
Java语言关键字
Java语言关键字
37 2
|
2月前
|
分布式计算 安全 Java
Java语言的特点?
Java语言的特点?