8.java数据结构与算法-递归(笔记)

一、递归调用机制

在这里插入图片描述
当程序执行到一个方法时,就会开辟一个独立的空间(栈)

在这里插入图片描述
每一个栈的数据n是独立的

在这里插入图片描述
开辟的新栈里n=2,所以执行输出语句,在控制台输出n=2

然后n=2的栈就被销毁,返回继续执行n=3那个栈
在n=3的栈里边if语句已经执行完,所以往下执行,执行输出语句,在控制台输出n=3

全部执行完毕:
在这里插入图片描述

二、递归需要遵守的规则

在这里插入图片描述
如果方法中使用的是引用类型或对象吗,每个栈用的数据就指向了同一份数据空间

在这里插入图片描述

如果形成死龟,就会出现栈溢出异常

三、递归实现迷宫问题

代码演示:

package digui;

public class MiGong {
	public static void main(String[] args) {
		int[][] args1 = new int[6][7];// 创建一个二维数组模拟迷宫
		for (int i = 0; i < 6; i++) {// 把迷宫的墙设为1
			for (int j = 0; j < 7; j++) {
				args1[0][j] = 1;
				args1[i][0] = 1;
				args1[5][j] = 1;
				args1[i][6] = 1;
			}
		}
		for (int i = 0; i < 6; i++) {// 输出一次未走过的迷宫
			for (int j = 0; j < 7; j++) {
				System.out.print(args1[i][j] + "\t");
			}
			System.out.println();
		}
		setWay(args1, 1, 1);// 调用递归方法
		System.out.println("-----------------------------------------------------------------");
		for (int i = 0; i < 6; i++) {// 输出走过的迷宫
			for (int j = 0; j < 7; j++) {
				System.out.print(args1[i][j] + "\t");
			}
			System.out.println();
		}
	}

	public static boolean setWay(int[][] args, int i, int j) {
		if (args[4][5] == 2) {// 如果终点是2不进入递归返回true
			return true;
		} else {
			if (args[i][j] == 0) {// 如果是0进入递归
				args[i][j] = 2;// 把为0的置为2表示走过
				if (setWay(args, i + 1, j)) {//向下走
					return true;
				} else if (setWay(args, i, j + 1)) {//向右走
					return true;
				} else if (setWay(args, i - 1, j)) {//向上走
					return true;
				} else if (setWay(args, i, j - 1)) {//向左走
					return true;
				} else {//如果全不能走则这个点是死点置为3并返回false退出递归
					args[i][j] = 3;
					return false;
				}
			} else {//如果不是0,则可能是1,2,3,这几个都不能走,所以直接返回flase
				return false;
			}
		}
	}
}

因为数组是引用对象,所以每个栈都作用于这个数组

迷宫得到的路径与我们的策略有关,除了下–>右–>上–>左还可以考虑别的

四、八皇后问题

各个皇后不可以在同一行或者同一列,也不可以在同一斜线上

思路分析:

在这里插入图片描述
代码演示:

package digui;

public class Queue {
	int max = 8;
	int[] arr = new int[max];// 创建一个一维数组再利用算法就可以实现八皇后问题

	public static void main(String[] args) {
		Queue queue = new Queue();
		queue.check(0);
	}

	// 写一个方法用来输出各个皇后的位置
	private void print() {
		for (int i = 0; i < arr.length; i++) {
			System.out.print(arr[i] + "\t");
		}
		System.out.println();
	}

	// 写一个方法判断皇后放置的位置是否合理
	// 因为传入的n是第n个皇后,各个皇后不可能在同一行,第几个皇后就在第几行
	// arr[n]=2表示是第n个皇后在第2列,arr[i]=arr[n]判断第n个皇后是否和之前的皇后在同一行
	// 棋盘是正方形,可以理解为当前皇后的行与之前皇后的差等于当前皇后的列与之前皇后的列差他们就在同一斜线
	// Math.abs(i - n) == Math.abs(arr[i] - arr[n])判断是否在同一斜线
	private boolean judge(int n) {
		for (int i = 0; i < n; i++) {
			if (arr[i] == arr[n] || Math.abs(i - n) == Math.abs(arr[i] - arr[n])) {
				return false;
			}
		}
		return true;
	}

	// 写一个方法把皇后放在合理的位置
	private void check(int n) {
		if (n == max) {//当n等于max时八个皇后就摆放完毕
			print();//输出八个皇后的位置
			return;
		}
		// 判断皇后位置是否合理并放入
		for (int i = 0; i < max; i++) {
			arr[n] = i;//让每一行的皇后从第一列开始
			if (judge(n)) {
				check(n + 1);
			}
		}
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

诸葛东_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值