网站首页 > java教程 正文
1.0 递归的说明
递归就是在一个函数中调用自身。这样做可以让我们解决一些问题,比如计算斐波那契数列、阶乘等。
递归函数一般包括两部分:基本情况和递归情况。基本情况是指当问题变得很小,可以直接得到答案时,递归就可以停止了。递归情况是指在解决问题的过程中,需要不断地调用自身来解决更小规模的问题。
对于递归这个算法,简单的来说,方法自身调用自身的时候,需要有终止的条件,在运行过程中不断的趋向终止条件。还有递归总的来说有两个动作:第一个动作是递出,方法不断的在栈区中创建出来,直到达到了条件就会停止。第二个动作,达到条件停止了,就会回归,指方法在栈区中依次执行完后就销毁。
2.0 用递归来实现相关问题
以下的问题都较为简单,采取直接用代码来演示。
2.1 递归 - 阶乘
代码如下:
2.2 递归 - 反向打印字符串
代码如下:
2.3 递归 - 二分查找
代码如下:
2.4 递归 - 冒泡排序
代码如下:
2.5 递归 - 冒泡排序2.0
对冒泡排序进行升级,假如 int[] arr = {2,1,1,3,4,5,9},这种只需要遍历一遍即可,但是对与已经用递归实现的冒泡不止遍历一次。因此,需要得到升级版冒泡排序。
思路为:对于后续的元素已经是排好序了,就不用再遍历了。每一次交换完元素之后记下来 i 索引,i 之后的元素已经是排好序的,i 之前的元素还需要继续遍历,看是否还需要交换。
代码如下:
2.6 递归 - 插入排序
思路:假设第一个元素已经排序好了的,在已经排好的元素的后一个元素记录为 low,这个 low 索引对应的元素需要用临时变量来接受,只要找到比这个索引对应的元素小的值,就可以插入到比它小的值的后一个索引位置了,当然,每一次对比之后,都需要往后移一个位置,以便直接插入。当 low 一直每一个加 1 ,当 low 等于数组的长度时,就该停止了继续递归下去了。
代码如下:
2.7 递归 - 斐波那契
代码如下:
2.8 递归 - 兔子问题
一个斐波那契的变体问题。
思路:观察第六个月的兔子个数,是否等于第四个月的兔子的总数加上第五个月的兔子总数;类推,第五个月的兔子个数,是否等于第四个月的兔子的总数加上第三个月的兔子总数;以此类推,是符合斐波那契逻辑的。
代码如下:
2.9 递归 - 青蛙爬楼梯
一个斐波那契的变体问题
题目如下:
实现思路: 一个阶梯一种跳法,两个阶梯两种跳法。重点,如果有四个阶梯,从后往前分析,分两种情况;第一种,从第二个台阶直接一下子跳两阶上来。第二种,从第三个台阶跳一阶上来。那么从考虑第一种情况,前面两阶是不是就是只有两种方法。考虑第二种情况,前面的三个台阶是不是就是前面已经算出来的方式跳法个数了。因此,这就是一个斐波那契的变体问题。
代码如下:
- 上一篇: Java 程序员必会的「垃圾回收」算法
- 下一篇: java算法题-两数之和(两数相加 java)
猜你喜欢
- 2024-10-01 《Java常用算法手册》限免哦(java常见算法笔试题)
- 2024-10-01 java算法题-两数之和(两数相加 java)
- 2024-10-01 SnowFlake 雪花算法(Java实现)(java雪花算法生成id重复?)
- 2024-10-01 Java 程序员必会的「垃圾回收」算法
- 2024-10-01 一文秒懂:多级时间轮,最顶尖的Java调度算法
- 2024-10-01 BAT大牛太强了,用46张PPT弄懂JVM、GC算法和性能调优
- 2024-10-01 写智能算法,到底是用java还是C++好?
- 2024-10-01 Java中的线性回归算法实现(java中的线性回归算法实现什么)
- 2024-10-01 软帝学院:这么常用的java基础算法,你可不能错过
- 2024-10-01 一个非常实用而且精妙的算法-并查集(java语言实现)
你 发表评论:
欢迎- 最近发表
-
- Java常量定义防暴指南:从"杀马特"到"高富帅"的华丽转身
- Java接口设计原则与实践:优雅编程的艺术
- java 包管理、访问修饰符、static/final关键字
- Java工程师的代码规范与最佳实践:优雅代码的艺术
- 编写一个java程序(编写一个Java程序计算并输出1到n的阶乘)
- Mycat的搭建以及配置与启动(mycat部署)
- Weblogic 安装 -“不是有效的 JDK Java 主目录”解决办法
- SpringBoot打包部署解析:jar包的生成和结构
- 《Servlet》第05节:创建第一个Servlet程序(HelloSevlet)
- 你认为最简单的单例模式,东西还挺多
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)