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

Java练习:递归的实操

刘广法2022年03月16日 16:42:08Java教程7310
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练习:递归的实操” 的相关文章

JDK的安装卸载以及环境配置

JDK的安装卸载以及环境配置

一、安装JDK首先应该先下载JDK,下面两个网站都是可以下载:下载地址:https://www.oracle.com/java/technologies/javase-downloads.htmlopenJDK 下载:http://jdk.java.net/下载的的就是下面这样的图标,版本号可能不一...

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

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

java学习:Java流程控制语句的相关测试题

第一题:将所有包含3的三位数整数相加求和。103 131 133 301类似。public static void main(String[] args) { int n = 100;// 从n开始三位数...

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

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

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

eclipse 自动提示功能的实现

eclipse 自动提示功能的实现

之前用的版本都是有提示的,最近安装的最新版没有提示,今天就设置让自动提示出来第一步:windows”->"preferences",弹出preferences设置窗口。第二步:在preferences中找到Java,依次展开列表"Editor"->...

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、水仙花:百位数的立方+十位数的地方+个位数的立方等于这个数本身。2、三位数中。具体的步骤:public static void main(String[] args) { int i =&nbs...

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

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

Java练习:百钱百鸡利用Java进行实现

今有100块钱,需要购买100只鸡,已知鸡的价格是:公鸡5元,母鸡3元,小鸡三只元,问:需要购买多少只公鸡、母鸡、小鸡?Java实现百鸡百钱的方法一: public static void main(String[] args) { for&n...

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

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

发表评论

访客

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