2022.02.27刺杀大使

这篇博客介绍了一种解决迷宫路径问题的方法,通过结合二分查找和深度优先搜索(DFS)策略,找到进入大使馆迷阵并打开所有机关的最低伤害路径。题目中要求找到一条从入口到所有机关的路径,使得路径上的最大伤害值最小。博主提供了输入格式、输出格式以及代码实现,代码中定义了迷阵的结构、方向数组、访问标记和目标变量,并通过DFS遍历检查特定伤害值是否可行。这是一个典型的路径规划问题,适用于寻找最优解的算法策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

2022.02.27刺杀大使

题目描述

某组织正在策划一起对某大使的刺杀行动。他们来到了使馆,准备完成此次刺杀,要进入使馆首先必须通过使馆前的防御迷阵。

迷阵由 n×m 个相同的小房间组成,每个房间与相邻四个房间之间有门可通行。在第 n 行的 m 个房间里有 m 个机关,这些机关必须全部打开才可以进入大使馆。而第 1 行的 m 个房间有 m 扇向外打开的门,是迷阵的入口。除了第 1 行和第 n 行的房间外,每个房间都被使馆的安保人员安装了激光杀伤装置,将会对进入房间的人造成一定的伤害。第 i 行第 j 列 造成的伤害值为$ p_{i,j}$ (第 1 行和第 n 行的 p 值全部为 0)。

现在某组织打算以最小伤害代价进入迷阵,打开全部机关,显然,他们可以选 择任意多的人从任意的门进入,但必须到达第 n 行的每个房间。一个士兵受到的伤害值为他到达某个机关的路径上所有房间的伤害值中的最大值,整个部队受到的伤害值为所有士兵的伤害值中的最大值。现在,这个恐怖组织掌握了迷阵的情况,他们需要提前知道怎么安排士兵的行进路线可以使得整个部队的伤害值最小。

输入格式

第一行有两个整数 n,m,表示迷阵的大小。

接下来 n 行,每行 m 个数,第 i 行第 j 列的数表示 pi,jp_{i,j}pi,j

输出格式

输出一个数,表示最小伤害代价。

样例输入

4 2
0 0
3 5
2 4
0 0

样例输出

3

思路

题目中即求从上到下的一条路径,满足路径上的最大数字最小。由于答案已经限定在了矩阵中的所有数字,所以可以采用二分查找解该题。
首先使用二分查找遍历所有可能的解,再使用dfs遍历该数是否可行。

代码

	int m, n;
	int a[][];
	int[][] dir = {
			{0,1},
			{0,-1},
			{1,0},
			{-1,0},
	};
	boolean[][] vis;
	int[] t;
	int tar;
	
	boolean check = false;
	
	boolean isIn(int i, int j) {
		return i>=0&&i<m&&j>=0&&j<n;
	}
	void dfs(int i, int j) {
		if(check) return;
		if(i == m-1) {
			check = true;
			
		} else {
			for(int k = 0; k < dir.length; k++) {
				int nx = i+dir[k][0];
				int ny = j+dir[k][1];
				if(isIn(nx,ny) && !vis[nx][ny] && a[nx][ny] <= tar) {
					vis[nx][ny] = true;
					dfs(nx,ny);
				}
			}
		}
	}
	
	boolean checkFun() {
		for(int i = 0; i < m; i++) for(int j = 0; j < n; j++) vis[i][j] = false;
		for(int i = 0; i < n; i++) {
			check = false;
			if(!vis[1][i] && a[1][i] <= tar) {
				vis[1][i] = true;
				dfs(1,i);
				if(check) return true;
			}
		}
		return false;
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值