本文主要讲述java中的递归机制。

示例1,递归代码如下:

public class Recursion01 {
public static void main(String[] args) {
T t = new T();
t.test(4);
} }
class T {
public void test(int n) {
if(n > 2) {
test(n-1);
}
System.out.println(n);
}
}

jvm处理递归机制如下图所示:

运行结果如下:

示例2,递归代码如下:

public class Recursion01 {
public static void main(String[] args) {
T t = new T();
t.test(4);
}
}
class T {
public void test(int n) {
if(n > 2) {
test(n-1);
}else {
System.out.println(n);
}
}
}

jvm处理递归机制如下图所示:

运行结果是2。

注意示例1和示例2的区别。示例1是执行test方法,就会打印当前的n,示例2是做出判断小于或者等于2的打印当前的n。

课堂练习:

1.斐波那契数列

public class Recursion02 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int key = scanner.nextInt();
// int num = new NumUtils().fun(key);
// if(num >= 1) {
// System.out.println("当n="+key+"时,对应的斐波那契数列:"+num);
// }else {
// System.out.println("输入数据无效");
// }
new NumUtils().Fibonacci(key);
} } class NumUtils {
// 斐波那契数列中指定索引的值
public int fun(int n) {
if(n > 2) {
return fun(n-1)+fun(n-2);
}
if(n == 1 || n == 2){
return 1;
}
return -1; } // 打印斐波那契数列
public void Fibonacci(int n) {
int a = 0,b = 1,c;
if(n > 1) {
System.out.print(1+" ");
for(int i =1;i<n;i++) {
c = a + b;
a = b;
b = c;
System.out.print(c +" ");
}
}else {
System.out.println("输入数据有误");
}
}
}

运行结果:

2.猴子吃桃问题:

/* 吃桃规则:每次吃剩余桃子的一半,加一。
* day10,还有1个桃
* day9,还有4 = (day10 + 1)*2个桃
* day8,还有10 = (day9 + 1)*2个桃
* ...
*/ public class Recursion03 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
int day = scanner.nextInt();
int res = new Monkey().Peach(day);
if(res != -1) {
System.out.println("当day="+day+"时,还有"+res+"个桃");
}else {
System.out.println("输入天数有误");
} }
}
class Monkey{ public int Peach(int day) { if(day == 10) {
return 1;
}
if(day >= 1 && day <10) {
return (Peach(day + 1)+1)*2;
} return -1;
}
}

3.迷宫问题

public class Migong {
public static void main(String[] args) { int [][] map = new int[8][7]; MiGongGraph graph = new MiGongGraph();
graph.CreateGraph(map);
graph.findWay2(map, 1, 1); System.out.println("===当前地图===");
for(int i =0;i<map.length;i++) {
for(int j = 0;j<map[0].length;j++) {
System.out.print(map[i][j]+" ");
}
System.out.println();
} } } class MiGongGraph {
public void CreateGraph(int[][] map) {
for(int j = 0;j < map[0].length;j++) {
map[0][j] = 1;
map[map.length-1][j] = 1;
} for(int i = 0;i<map.length;i++) {
map[i][0] = 1;
map[i][map[0].length-1] = 1;
}
map[3][1] = 1;
map[3][2] = 1;
map[2][2] = 1;
} /*
* 0表示还没有走,不是障碍物,
* 1表示障碍物,
* 2表示走过,无法确定是否是死路
* 3表示走过,但是走不通,是死路。
*
* 走路的顺序,右->下->上->左
*/
public boolean findWay(int [][] map,int i,int j) {
// map[5][6] = 2时,说明已经走出迷宫。
if(map[6][5] == 2) {
return true;
}else {
// 递归体:
// 判断当前坐标是否已经走过
if(map[i][j] == 0) {
// 没有走过,则将其对应的二维数组的值置为2
map[i][j] = 2; // 沿着这个点,按照顺序,走路。
// 首先是这个点的右边
if(findWay(map, i, j+1)) {
return true;
// 接着是这个点的下边
}else if(findWay(map, i+1, j)) {
return true;
// 接着是这个点的上边
}else if(findWay(map, i-1, j)) {
return true;
// 最后是这个点的左边
}else if(findWay(map, i, j-1)) {
return true;
}else {
// 由于该点的右->下->上->左,都不能走通,则该点是死路,置为3。
map[i][j] = 3;
return false;
}
// 已经走过,不回溯。
}else {
return false;
}
}
} public boolean findWay2(int [][] map,int i,int j) {
if(map[6][5] == 2) {
return true;
}else {
// 递归体:
// 判断当前坐标是否已经走过
if(map[i][j] == 0) {
// 没有走过,则将其对应的二维数组的值置为2
map[i][j] = 2; // 沿着这个点,按照顺序,走路。
// 首先是这个点的下边
if(findWay(map, i+1, j)) {
return true;
// 接着是这个点的右边
}else if(findWay(map, i, j+1)) {
return true;
// 接着是这个点的上边
}else if(findWay(map, i-1, j)) {
return true;
// 最后是这个点的左边
}else if(findWay(map, i, j-1)) {
return true;
}else {
// 由于该点的右->下->上->左,都不能走通,则该点是死路,置为3。
map[i][j] = 3;
return false;
}
// 已经走过,不回溯。
}else {
return false;
}
}
}
}

4.汉诺塔问题:

汉诺塔规则:a,b,c三柱,将从上往下看由小到大的塔,由a柱搬到c柱。塔仍保持从上往下看,由小到大。

public class HanNoTa {
public static void main(String[] args) {
Tower tower = new Tower();
tower.Method(3, 'A', 'B', 'C');
} } class Tower { // num是盘子的总数,a,b,c是指代三根柱子。
public void Method(int num,char a,char b,char c) {
if(num == 1) {
System.out.println(a +"->"+c);
}else {
// 将汉诺塔分成最后一个盘和上面的盘,两个部分
// 先将上面的盘,借助c柱,由a柱搬到b柱
Method(num-1, a, c, b);
// 此时只剩下最后一个盘,直接由a柱搬到c柱
System.out.println(a+"->"+c);
// 还需要将上面的盘,由b柱移动到c柱
// System.out.println(b+"->"+c);
// 将上面的盘子,借助a柱,由b柱搬到c柱。
// 不能直接由b柱到c柱,违背汉诺塔的规则。
Method(num-1, b, a, c); }
}
}

java中的递归机制的更多相关文章

  1. Java中的递归运算

    Java中的递归运算是一种在自己的方法内部调用自己的方法 递归的设计思想是:把一个复杂的问题,分解为若干个等同的子问题,重复执行,直到之问题能够简单到直接求解,这样复杂的问题就得以解决. 递归运算有两 ...

  2. java中的反射机制在Android开发中的用处

    JAVA反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对于任意一个对象,都能够调用它的任意一个方法和属性:这种动态获取的信息以及动态调用对象的方法的功能称为java语言的反 ...

  3. java中wait/notify机制

    通常,多线程之间需要协调工作.例如,浏览器的一个显示图片的线程displayThread想要执行显示图片的任务,必须等待下载线程 downloadThread将该图片下载完毕.如果图片还没有下载完,d ...

  4. 浅说Java中的反射机制(二)

    写过一篇Java中的反射机制,不算是写,应该是抄了,因为那是别人写的,这一篇也是别人写的,摘抄如下: 引自于Java基础--反射机制的知识点梳理,作者醉眼识朦胧.(()为我手记) 什么是反射? 正常编 ...

  5. 浅说Java中的反射机制(一)

    在学习传智播客李勇老师的JDBC系列时,会出现反射的概念,由于又是第一次见,不免感到陌生.所以再次在博客园找到一篇文章,先记录如下: 引用自java中的反射机制,作者bingoideas.(()为我手 ...

  6. 【笔试题】Java 中如何递归显示一个目录下面的所有目录和文件?

    笔试题 Java 中如何递归显示一个目录下面的所有目录和文件? import java.io.File; public class Test { private static void showDir ...

  7. 【Java】深入理解Java中的spi机制

    深入理解Java中的spi机制 SPI全名为Service Provider Interface是JDK内置的一种服务提供发现机制,是Java提供的一套用来被第三方实现或者扩展的API,它可以用来启用 ...

  8. 2018.3.31 java中的递归

    java中的递归 1.概念 定义一个方法时,出现本方法调用本方法的过程,称之为递归 2.特点 必然有一个边界条件 使用递归代码往往更简洁,可读性强 3.什么时候使用递归 n的阶乘和n的累加定义 f(n ...

  9. 【Java基础】java中的反射机制与动态代理

    一.java中的反射机制 java反射的官方定义:在运行状态下,可以获取任意一个类的所有属性和方法,并且可通过某类任意一对象实例调用该类的所有方法.这种动态获取类的信息及动态调用类中方法的功能称为ja ...

随机推荐

  1. [题解] HDU 5115 Dire Wolf 区间DP

    考虑先枚举所有的物品中最后拿走的,这样就分成了2个子问题,即先拿完左边的,再拿完右边的,最后拿选出的那个.令dp(i,j)表示拿完[i,j]所有物品的最小代价.你可能会说,我们拿[i,j]这一段物品的 ...

  2. Python实现改进后的Bi-RRT算法实例

    Python实现改进后的Bi-RRT算法实例 1.背景说明 以下代码是参照上海交通大学海洋工程国家重点实验室<基于改进双向RRT的无人艇局部路径规划算法研究>的算法思想实现的. 2.算法流 ...

  3. k8s 中的 service 如何找到绑定的 Pod 以及如何实现 Pod 负载均衡

    k8s 中的 service 如何找到绑定的 Pod 以及如何实现 Pod 负载均衡 前言 endpoint kube-proxy userspace 模式 iptables ipvs kernels ...

  4. 《Vue3.x+TypeScript实践指南》已出版

    转眼回长沙快2年了,图书本在去年就已经完稿,因为疫情,一直耽搁了,直到这个月才出版!疫情之下,众生皆苦!感觉每天都是吃饭.睡觉.上班.做核酸! 图书介绍 为了紧跟技术潮流,该书聚焦于当下火的Vue3和 ...

  5. Dest0g3迎新赛misc部分解析

    ​ 目录 1. Pngenius 2. EasyEncode 3. 你知道js吗 4. StrangeTraffic 5. EasyWord 6.4096 7.python_jail 8. codeg ...

  6. go-zero docker-compose 搭建课件服务(九):http统一返回和集成日志服务

    0.索引 go-zero docker-compose 搭建课件服务(九):http统一返回和集成日志服务 0.1源码地址 https://github.com/liuyuede123/go-zero ...

  7. python基础之标识符、注释与变量

    一.注释 1.作用:注释是用来解释和说明代码的. 2.分类:注释可以分为单行注释和多行注释 2.1.单行注释:在编写的代码或文字前加上"#",表示单行注释 1 #我是单行注释 2 ...

  8. 消息队列之RabbitMQ介绍与运用

    RabbitMQ 说明 本章,我们主要从RabbitMQ简介.RabbitMQ安装.RabbitMQ常用命令.RabbitMQ架构模式.RabbitMQ使用.Quick.RabbitMQPlus的使用 ...

  9. $_SERVER["REQUEST_URI"],在 PHP 众多预定义服务器变量中,$_SERVER["REQUEST_URI"] 算是经常用到的,但是这个变量只有 apache 才支持

    例如访问:http://localhost/index.php?app=lunbo获取到的$_SERVER["REQUEST_URI"]为"/index.php?app= ...

  10. 题解 UVA10285 最长的滑雪路径 Longest Run on a Snowboard

    Solution 双倍经验 就是记搜嘛. 搞一个二维数组记录一下当前的最长滑雪路径,其他和普通 dfs 没什么两样. 向 \(4\) 个方向搜索,如果高度符合就 \(+1\) . 多测要注意数组初始化 ...