当前位置:首页 > 学习笔记 > Java教程 > Java练习:递归的实操

Java练习:递归的实操

刘广法2022年03月16日 16:42:08Java教程3480
Java练习:递归的实操-第1张图片-刘广法IT博客

Java学习:递归的实操

递归就是直接或者间接调用滋生。需要注意的就是,一定要有一个判断条件让这个死循环结束。

Java学习递归实操训练一:

利用递归算出10的阶乘:

此方法是常规方法:<主要用作和下面用递归的对比>

	public static void main(String[] args) {
		// 非递归,十的阶乘
		System.out.println(results(10));
	}

	public static int results(int x) {
		int sum = 1;
		for (int i = x; i > 1; i--) {
			sum *= i;
		}
		return sum;
	}

此方法为递归方法:

	public static void main(String[] args) {
		// 递归,十的阶乘
		System.out.println(results(10));
	}
	public static int results(int x) {
		if(x == 1) {
			return 1;
		}
		return results(x - 1) * x;
	}

Java控制台输出结果为:3628800

利用递归算出100的阶加:

此方法为阶加方法:

	public static void main(String[] args) {
		// 递归,十的阶加
		System.out.println(results(100));
	}
	public static int results(int x) {
		if(x == 0) {
			return 0;
		}
		return results(x - 1) + x;
	}

Java控制台输出结果为:5050

利用递归玩游戏 - 汉诺塔(相对比较难):

Java练习:递归的实操-第2张图片-刘广法IT博客

将 柱子A 中的所有套圈转移到 柱子C 上。

思路:利用递归思路,把套圈假设为 n 个,将 n 转换 成 n - 1 的问题:

	public static void main(String[] args) {
		// 递归
		game('A', 'B', 'C', 3);
	}

	public static void game(char a, char b, char c, int n) {
		if (n == 1) {
			System.out.println(a + "=>" + b);
			return;
		}
		// 将第n-1个由A=>C
		game(a, c, b, n - 1);
		// 将第n个由A=>B
		System.out.println(a + "=>" + b);
		// 将第n-1由C=>B
		game(c, b, a, n - 1);
		
	}

Java控制台输出结果:

A=>B
A=>C
B=>C
A=>B
C=>A
C=>B
A=>B

这就是将3层的汉诺塔移动的步骤。


接下来我们也能用递归解决我们之前遇到的问题:输出数列1 1 2 3 5 8 13 21 34 55...第25项的值

如果想要查看使用 非递归来解决请点击输出数列1 1 2 3 5 8 13 21 34 55...第25项的值

下面使用递归解决:

刘广法整理的思路,第 n 项的值等于第(n-1)的项和第(n-2)的项的和。

	public static void main(String[] args) {
		// 递归:输出数列1 1 2 3 5 8 13 21 34 55...第25项的值
		System.out.println(sum(5));
	}

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

Java控制台的输出结果:8

作者:域名博客,网站地址:https://liuguangfa.com/,转载注明出处!

扫描二维码推送至手机访问。

版权声明:本文由刘广法博客发布,如需转载请注明出处。

本文链接:https://liuguangfa.com/java/122.html

分享给朋友:

“Java练习:递归的实操” 的相关文章

Java教程 第二节:基本数据类型与变量

一、关键词在java中有特殊含义的一些词,比方说 public class 等。break;break 主要用在循环语句或者 switch 语句中,用来跳出整个语句块。break 跳出最里层的循环,并且继续执行该循环下面的语句。二、标识符起唯一标识作用的,类似我们自己的姓名,学校中的学号,公司中的工...

使用eclipse进行文件的导入和导出

使用eclipse进行文件的导入和导出

该说不说,学会这个项目可以省很多的事情,刘广法可以用这个方法借鉴同学的项目,可以进行参考、借鉴、以及抄作业。一、使用eclipse进行项目的导出:1、使用eclipse进行项目的导出第一步:找到所在的项目工作空间,如果你知道的话,可以直接打开文件进行打包发送给你的好友,如果想要知道项目工作空间如何修...

Java教程 第四节:流程控制语句总结

流程控制语句:一、顺序结构顺序结构:按照写代码的顺序 一次执行二、分支结构1、if语句if(条件){     语句块 }2、if...else...语句if(条件){     语句块 }else{  ...

eclipse删除工作空间的详细步骤(图解)

eclipse删除工作空间的详细步骤(图解)

上一次我修改添加eclipce的工作空间,但只我的eclipce上有两个工作空间,今天我想删除一个第一步: Window > Preferences > General > startup and shutdown -->workspace这就是删除eclipse的...

eclipse的快捷键功能

eclipse的快捷键功能

有一些快捷键是可以修改的,具体修改过程如图下:修改快捷的详细步骤:1、使用快捷键调出快捷键列表进行查看:快捷键列表调用:shift + ctrl + L2、window->preferences->general->keys(或直接搜索keys)快捷键列表:shuft + ctrl...

eclipse 修改默认的工作空间以及修改个人工作空间的编码

eclipse 修改默认的工作空间以及修改个人工作空间的编码

一、修改工作空间workspaceFile-->Awitch Workspace-->Other,就打开下面的图,然后选择我标起来的就可以新建工作空间了。二、设置工作空间workspace的编码为UTF-8设置完你所用的工作空间也就是上一步后,需要修改工作空间的编码为UTF-8步骤如下:...

eclipse 如何更换JDK版本 替换自带的JDK版本

eclipse 如何更换JDK版本 替换自带的JDK版本

设置jdk,用安装的JDK替换eclipse自带的JDK(详细步骤)1、Window-->Presferences2、进入后,搜索“java”,找到“Installed JRES”3、删除自带的JDK:选中自带的jdk,然后选择remove。4、添加自己安装的JDK:选中右边的Add,选择St...

用Java实现打印各种图形总结篇(矩形、平行四边形、三角形、菱形)

1、用Java实现打印矩形(长方形、正方形): public static void main(String[] args) { for (int y = 0; y < ...

Java练习:打印出所有3位数的素数

课堂练习:打印出所有3位数的素数。素数:只能被1和其本身整除的数 public static void main(String[] args) { // 打印三位数的素数,素数只能被1和本身整数的数。 for (int...

Java练习:将数组中的元素首尾调换

数组课堂练习:将数组中的元素首尾调换 public static void main(String[] args) { // 数组课堂练习:将数组中的元素首尾调换 int[] a = { ...

Java练习:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数

Java课后作业:定义一共整数数组a,b,两个数组,判断两个数组中的重复的元素以及重复次数问题1:判断两个数组中重叠的元素?问题2:重叠的元素都重叠了几次,进行排序输出?本题关键:去重(验证之前是否验证过此数)、排序,(冒泡排序法和选择排序法)、关键字break 和continue 的使用 //&n...

Java练习:定义一个函数,计算两个整数的最大公约数

Java面试题:定义一个函数,计算两个整数的最大公约数本题关键点:最大的公约数能够被两个数都整除的数 public static void main(String[] args) { // 定义一个函数,计算两个整数的最大公约数...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。