LeetCode 2596. 检查骑士巡视方案【数组,模拟】1448

news2024/12/23 19:32:50

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,还会用多种编程语言实现题解,涉及到通用解法时更将归纳总结出相应的算法模板。

为了方便在PC上运行调试、分享代码文件,我还建立了相关的仓库。在这一仓库中,你不仅可以看到LeetCode原题链接、题解代码、题解文章链接、同类题目归纳、通用解法总结等,还可以看到原题出现频率和相关企业等重要信息。如果有其他优选题解,还可以一同分享给他人。

由于本系列文章的内容随时可能发生更新变动,欢迎关注和收藏征服LeetCode系列文章目录一文以作备忘。

骑士在一张 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 中的所有整数 互不相同

解法 直接模拟

题目要求骑士的移动的每一步均按照「日」字形跳跃,假设从位置 ( x 1 , y 1 ) (x_1, y_1) (x1,y1) 跳跃到 ( x 2 , y 2 ) (x_2, y_2) (x2,y2) ,则此时一定满足下面两种情形之一:
∣ x 1 − x 2 ∣ = 1 , ∣ y 1 − y 2 ∣ = 2 |x_1 - x_2| = 1, |y_1 - y_2| = 2 x1x2=1,y1y2=2

设矩阵的长度为 n n n ,其中 g r i d [ r o w ] [ c o l ] grid[row][col] grid[row][col] 表示单元格 ( r o w , c o l ) (row,col) (row,col)是骑士访问的第 g r i d [ r o w ] [ c o l ] grid[row][col] grid[row][col] 个单元格,因此可以知道每个单元格的访问顺序,我们用 i n d i c e s indices indices 存储单元格的访问顺序,其中 i n d i c e s [ i ] indices[i] indices[i] 表示骑士在经过第 i − 1 i-1 i1 次跳跃后的位置。

由于骑士的行动是从下标 0 0 0 开始的,因此一定需要满足 g r i d [ 0 ] [ 0 ] = 0 grid[0][0]=0 grid[0][0]=0 ,接下来依次遍历 i n d i c e s indices indices 中的每个元素。由于 i n d i c e s [ i ] indices[i] indices[i] 是一次跳跃的起点, i n d i c e s [ i + 1 ] indices[i+1] indices[i+1] 是该次跳跃的终点,则依次检测每一次跳跃的行动路径是否为「日」字形,即满足如下条件:

  • ∣ indices [ i ] [ 0 ] − indices [ i + 1 ] [ 0 ] ∣ = 1 , ∣ indices [ i ] [ 1 ] − indices [ i + 1 ] [ 1 ] ∣ = 2 ∣ |\textit{indices}[i][0] - \textit{indices}[i+1][0]| = 1, |\textit{indices}[i][1] - \textit{indices}[i+1][1]| = 2∣ indices[i][0]indices[i+1][0]=1,indices[i][1]indices[i+1][1]=2
  • ∣ indices [ i ] [ 0 ] − indices [ i + 1 ] [ 0 ] ∣ = 2 , ∣ indices [ i ] [ 1 ] − indices [ i + 1 ] [ 1 ] ∣ = 1 ∣ |\textit{indices}[i][0] - \textit{indices}[i+1][0]| = 2, |\textit{indices}[i][1] - \textit{indices}[i+1][1]| = 1∣ indices[i][0]indices[i+1][0]=2,indices[i][1]indices[i+1][1]=1

为了方便计算,我们只需检测 ∣ x 1 − x 2 ∣ × ∣ y 1 − y 2 ∣ |x_1 - x_2| \times |y_1 - y_2| x1x2×y1y2 ​是否等于 2 2 2 即可。如果所有跳跃路径均合法则返回 true \text{true} true ,否则返回 false \text{false} false

class Solution {
public:
    bool checkValidGrid(vector<vector<int>>& grid) {
        if (grid[0][0] != 0) return false;
        int n = grid.size();
        vector<array<int, 2>> indices(n * n);
        for (int i = 0; i < n; ++i) 
            for (int j = 0; j < n; ++j)
                indices[grid[i][j]] = {i, j};
        for (int i = 1; i < indices.size(); ++i) {
            int dx = abs(indices[i][0] - indices[i - 1][0]);
            int dy = abs(indices[i][1] - indices[i - 1][1]);
            if (dx * dy != 2) return false;
        }
        return true;
    }
};

复杂度分析:

  • 时间复杂度: O ( n 2 ) O(n^2) O(n2) ,其中 n n n 表示二维棋盘边的长度。需要检测棋盘中的每个位置,一共需要检测 n 2 n^2 n2 个位置,因此时间复杂度为 O ( n 2 ) O(n^2) O(n2)
  • 空间复杂度: O ( n 2 ) O(n^2) O(n2) ,其中 n n n 表示二维棋盘边的长度。用来需要存放每个位置的访问顺序,一共有 n 2 n^2 n2 个位置,需要的空间为 O ( n 2 ) O(n^2) O(n2)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1006092.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【markdown】How to use markdown

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

flink-1.14.4启动报错setPreferCheckpointForRecovery(Z)v

从flink1.12升级到flink1.14&#xff0c;修改了pom.xml的flink-version&#xff0c;打包的时候发现报错&#xff1a; // 当有较新的 Savepoint 时&#xff0c;作业也会从 Checkpoint 处恢复env.getCheckpointConfig().setPreferCheckpointForRecovery(true); 于是屏蔽了这段配置…

什么样的护眼灯好?盘点五款好用的护眼台灯

随着技术的发展&#xff0c;灯光早已成为每家每户都需要的东西。但是灯光不好可能会对眼睛造成伤害是很多人没有注意到的。现在随着护眼灯产品越来越多&#xff0c;市场上台灯的选择越来越多样化&#xff0c;如何选择一个对眼睛无伤害、无辐射的台灯成为许多家长首先要考虑的问…

21.(地图工具篇)geoserver发布wms服务文字被裁剪

1&#xff1a;问题描述 Partials:当标签在瓦片边缘显示不全时&#xff0c;是否绘制。 当设置partials时为true时&#xff08;默认为false&#xff09;&#xff0c;出现以下问题&#xff08;文字被裁剪&#xff09;&#xff1a; 2&#xff1a;解决方案 设置缓冲后&#xff…

如何利用Api接口获取手机当前的网络位置信息

在移动互联网时代&#xff0c;手机定位已经成为了一个日常化的需求&#xff0c;无论是导航、社交还是打车等服务都需要获取手机的位置信息。而获取手机位置信息最基础的一步就是获取手机当前的网络位置信息&#xff0c;本文将介绍如何利用API接口获取手机当前的网络位置信息。 …

《使用 Helm 管理 Kubernetes 应用程序的最佳实践》

&#x1f337;&#x1f341; 博主猫头虎&#xff08;&#x1f405;&#x1f43e;&#xff09;带您 Go to New World✨&#x1f341; &#x1f405;&#x1f43e;猫头虎建议程序员必备技术栈一览表&#x1f4d6;&#xff1a; &#x1f6e0;️ 全栈技术 Full Stack: &#x1f4da…

职业规划就问它!海量知识与智慧,AIGC助你冲破择业迷茫

数字化时代的兴起改变了我们的日常生活和职业工作方式。科技迅猛的发展&#xff0c;尤其是人工智能的崛起&#xff0c;将我们引入了一个崭新的智能化时代。在这个时代中&#xff0c;AI被认为是从"数字时代"向"数智时代"转变的关键元素&#xff0c;引领着这…

学校安全升级,门禁管理就选它了!

门禁监控系统是一项在当今教育界日益受到重视的技术应用&#xff0c;它不仅仅是一种安全措施&#xff0c;更是一种校园管理和学生安全保障的创新方法。 在这一背景下&#xff0c;门禁监控系统成为了一种重要的解决方案&#xff0c;能够确保学生和教职员工的安全&#xff0c;提高…

融云聊天室再放大招,服务更完整、集成更便捷

9 月 21 日&#xff0c;融云直播课 社交泛娱乐出海最短变现路径如何快速实现一款 1V1 视频应用&#xff1f; 欢迎点击上方小程序报名~ 聊天室是直播、语聊房等社交泛娱乐产品的必备组件&#xff0c;它以“公屏”形态面向用户。关注【融云全球互联网通信云】了解更多 作为一个…

C#+sqlserver网上作业批改与管理系统asp.net

功能需求 3.3.1 学生部分 1&#xff1a;查看发布作业&#xff1a;以列表的形式查看教师发布的作业。 2&#xff1a;上交作业&#xff1a;学生上交教师发布的作业。 需输入作业名称及添加WORD文档地址进行作业上传。 3&#xff1a;查看已上交作业&#xff1a;以列表的形式查看…

正中优配:股票重组前最明显的特征?

股票重组是指一家公司在经过一定的调整后&#xff0c;对其股票进行重新组合和发行的进程。股票重组是一种非常常见的商业行为&#xff0c;它能够协助公司提高效率、操控成本&#xff0c;提高股价等目的。在股票重组前&#xff0c;有许多显着的特征能够协助我们了解公司的情况以…

一款释放数据价值的项目,开源了!

在大数据和 AI 的时代背景下&#xff0c;数据已经成为了重要财富&#xff0c;大到政务数据、企业核心数据&#xff0c;小到个人信息、银行卡余额&#xff0c;这些数据无一例外都是“隐私数据”&#xff0c;如果在使用和流转时发生泄漏都会造成巨大的损失。 那有没有什么方法&a…

骨传导耳机对人体有危险吗?会损害听力吗?

如果在使用骨传导耳机的时候控制好时间和音量&#xff0c;是不会对人体带来危险和造成伤害的。 下面跟大家解释一下为什么骨传导耳机对人体没有危害&#xff0c;最大的原因就是骨传导耳机不需要空气传导&#xff0c;而是通过颅骨传到听觉中枢&#xff0c;传输过程中几乎没有噪…

U8G2 各显示屏初始化过程

主函数&#xff1a;u8g2lib.h --------各显示屏初始化函数 u8g2_d_setup.c-------- 主要函数 u8g2_SetupDisplay (u8g2, u8x8_d_ist3088_320x240, u8x8_cad_011, byte_cb, gpio_and_delay_cb); u8x8_d_ist3088_320x240, u8x8_cad_011 对应相应的初始化函数

Linux更新g++

不同版本的g会支持不同的c标准&#xff0c;若是g标准过低会导致一些c新的标准无法使用。 比如c11出的regex就需要g 4.9以上的标准才能使用。 一般更新g需要使用一些额外的软件源&#xff0c;便于我们更新g&#xff0c;这里采用Developer ToolSet来更新g。 更新步骤 首先使用ro…

易基因: WGBS等揭示DNA甲基化调控林地草莓植株高度和果实大小的分子机制|植物发育

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 DNA甲基化影响基因组稳定性、转座子沉默和基因表达&#xff1b;它主要发生在对称CG和CHG以及不对称CHH (H A, C或T)中的胞嘧啶上。RNA介导的DNA甲基化(RNA-directed DNA methylation&am…

Containerd安装详细步骤

Containerd安装详细步骤 从k8s的1.24版本开始&#xff0c;k8s默认的容器运行时就是Containerd了&#xff0c;所以想要安装学习k8s的1.24以后的版本 都需要安装Containerd&#xff0c;废话不多说&#xff0c;请看以下安装步骤。 1、离线安装包下载地址 https://github.com/con…

Layui快速入门之第四节 按钮

目录 一&#xff1a;基本用法 二&#xff1a;不同主题的按钮 基本案例&#xff1a; 三&#xff1a;不同尺寸的按钮 基本案例&#xff1a; 四&#xff1a;按钮圆角 五&#xff1a;按钮图标 六&#xff1a;按钮混搭 七&#xff1a;按钮组合 八&#xff1a;按钮容器 一…

基于Android高校智慧公寓选房APP的设计与实现

基于Android高校智慧公寓选房APP的设计与实现 摘 要 学生宿舍选房是大学新生入学必须面临的问题。能够统计各宿舍的分配使用情况&#xff0c;清楚查看宿舍状态&#xff0c;图像化展示&#xff0c;一目了然。并与其它系统共用一个数据中心&a…

PDF怎么转图片?四种转换方法分享

PDF文件是一种非常常见的文档格式&#xff0c;然而&#xff0c;有时候我们需要将PDF文件转换成图片格式。比如我们可能需要将PDF文件中的某些页面或图表转换成图片格式以便于编辑或分享。在这篇文章中&#xff0c;我们将介绍四种将PDF文件转换成图片的方法。 方法一&#xff1a…