Leetcode 6322. 检查骑士巡视方案 暴力模拟法 第337场周赛,第二题
创始人
2025-05-30 19:03:53
0

题目描述

骑士在一张 n x n 的棋盘上巡视。在有效的巡视方案中,骑士会从棋盘的 左上角 出发,并且访问棋盘上的每个格子 恰好一次 。

给你一个 n x n 的整数矩阵 grid ,由范围 [0, n * n - 1] 内的不同整数组成,其中 grid[row][col] 表示单元格 (row, col) 是骑士访问的第 grid[row][col] 个单元格。骑士的行动是从下标 0 开始的。

如果 grid 表示了骑士的有效巡视方案,返回 true;否则返回 false。

注意,骑士行动时可以垂直移动两个格子且水平移动一个格子,或水平移动两个格子且垂直移动一个格子。下图展示了骑士从某个格子出发可能的八种行动路线。

示例 1:

输入:grid = [[0,11,16,5,20],[17,4,19,10,15],[12,1,8,21,6],[3,18,23,14,9],[24,13,2,7,22]]
输出:true
解释:grid 如上图所示,可以证明这是一个有效的巡视方案。
示例 2:

输入:grid = [[0,3,6],[5,8,1],[2,7,4]]
输出:false
解释:grid 如上图所示,考虑到骑士第 7 次行动后的位置,第 8 次行动是无效的。

提示:

n == grid.length == grid[i].length
3 <= n <= 7
0 <= grid[row][col] < n * n
grid 中的所有整数 互不相同

题目地址

Leetcode 6322. 检查骑士巡视方案

思路分析

  1. 首先要求骑士必须从下标0开始行动,这里需要判断 grid[0][0] == 0,这种情况,我自己在做的时候就忘记了这种情况,导致一个测试用例过不去,很难受。
  2. 通过骑士的站位,判断其8个点位中合法点位的值,是否和现在所占据的点位的值是否差1,即判断 grid[i][j] + 1 == 可能的8个点位的值。如果有,则说明可以跳到下一个位置,循环进行,8个点位都没有,则直接跳出循环,即无法巡视完棋盘,返回false。
  3. 当点位的值+1,是否和棋盘的长乘宽相等,即 grid[i][j] + 1 == gird.length * grid[0].length ,如果想等则已经巡视完全程,否则会回到步骤二,再进行判断。

代码示例

public class Solution {public boolean checkValidGrid(int[][] grid) {if (grid[0][0] != 0) {return false;}int[] ret = checkArri(0, 0, grid);while (ret != null) {ret = checkArri(ret[0], ret[1], grid);if (ret == null) {return false;}if (grid[ret[0]][ret[1]] + 1 == grid.length * grid[0].length) {return true;}}return false;}public int[] checkArri(int i, int j, int[][] grid) {int len_i = grid.length;int len_j = grid[0].length;if (i - 1 >= 0 && i - 1 < len_i && j - 2 >= 0 && j - 2 < len_j) {if (grid[i - 1][j - 2] == grid[i][j] + 1) {return new int[]{i - 1, j - 2};}}if (i - 1 >= 0 && i - 1 < len_i && j + 2 >= 0 && j + 2 < len_j) {if (grid[i - 1][j + 2] == grid[i][j] + 1) {return new int[]{i - 1, j + 2};}}if (i + 1 >= 0 && i + 1 < len_i && j - 2 >= 0 && j - 2 < len_j) {if (grid[i + 1][j - 2] == grid[i][j] + 1) {return new int[]{i + 1, j - 2};}}if (i + 1 >= 0 && i + 1 < len_i && j + 2 >= 0 && j + 2 < len_j) {if (grid[i + 1][j + 2] == grid[i][j] + 1) {return new int[]{i + 1, j + 2};}}if (i - 2 >= 0 && i - 2 < len_i && j - 1 >= 0 && j - 1 < len_j) {if (grid[i - 2][j - 1] == grid[i][j] + 1) {return new int[]{i - 2, j - 1};}}if (i - 2 >= 0 && i - 2 < len_i && j + 1 >= 0 && j + 1 < len_j) {if (grid[i - 2][j + 1] == grid[i][j] + 1) {return new int[]{i - 2, j + 1};}}if (i + 2 >= 0 && i + 2 < len_i && j - 1 >= 0 && j - 1 < len_j) {if (grid[i + 2][j - 1] == grid[i][j] + 1) {return new int[]{i + 2, j - 1};}}if (i + 2 >= 0 && i + 2 < len_i && j + 1 >= 0 && j + 1 < len_j) {if (grid[i + 2][j + 1] == grid[i][j] + 1) {return new int[]{i + 2, j + 1};}}return null;}
}

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...