LeetCode每日一题:2596. 检查骑士巡视方案(2023.9.13 C++)

目录

[2596. 检查骑士巡视方案](#2596. 检查骑士巡视方案)

题目描述:

实现代码与解析:

bfs模拟

原理思路:


2596. 检查骑士巡视方案

题目描述:

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

实现代码与解析:

bfs模拟

cpp 复制代码
class Solution {
public:
    bool checkValidGrid(vector<vector<int>>& grid) {

        int n = grid.size(), m = grid[0].size(); // 边界范围

        int curx = 0, cury = 0; // 当前位置
        if (grid[0][0] != 0) return false;
        // 不用找起点,这题必须是左上角起点,就算是对的,不是左上角起点也判为false
        // for (int i = 0; i < n; i++)
        //     for (int j = 0; j < m; j++)
        //         if (grid[i][j] == 0) curx = i, cury = j;

        int num = 1; // 当前位置的下一个数字
        int target = n * m; // 目标值
        
        // 偏移量
        int dx[8] = {-2, -2, -1, -1, 1, 1, 2, 2};
        int dy[8] = {1, -1, 2, -2, -2, 2, 1, -1};

        while(true)
        {
            // cout << curx << " " << cury << endl;
            int flag = 0; // 8个方向有无正确可走方向
            for (int i = 0; i < 8; i++)
            {
                int x = curx + dx[i], y = cury + dy[i];
                if (x < 0 || x >= n || y < 0 || y >= m) continue;
                if (grid[x][y] == num)
                {
                    curx = x;
                    cury = y;
                    num++;
                    flag = 1;
                    break; // 记得写
                }     
            }
            if (num == target) return true; // 整个地图走完了,返回true
            // cout << "num:" <<num << endl;
            if (flag == 0) return false; // 无方向可走
        }
    }
};

原理思路:

模拟,可走格子中没有下一个数字,且不是最后一个数字,直接返回false。若在可走方格中找到下一个数字,那么就移动到此格子中,知道走到最后一个数字。

比较简单,主要看代码注释就行。

相关推荐
草履虫建模1 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq3 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq3 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq4 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)5 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi5 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱5 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头5 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头6 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱7 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法