【力扣每日一题】2023.9.13 检查骑士巡视方案

目录

题目:

示例:

分析:

代码:


题目:

示例:

分析:

题目给我们一个n*n大小的矩阵,矩阵的元素表示骑士已经行动的次数,问我们骑士能不能按照矩阵里元素顺序来巡视整个矩阵。

骑士每次移动的方案有八种,类似于中国象棋里的马走日。

骑士在左右和上下两种方向之中,每次移动都是先移动一种方向两格,再移动另一个方向一格,那么每次移动的点是固定的八个点,因此我们只需要在这八个点中寻找元素等于当前所在格子的元素+1的位置,如果找不到,那么就表示骑士无法按照矩阵中的顺序去巡视。

我们使用递归去寻找每个点,题目有说一开始骑士在左上角,因此我们从左上角开始递归,我们不断按照上诉的过程递归,直到我们把矩阵中所有格子都走一遍了,也就是递归了n*n+1次,那么表示骑士可以按照矩阵的顺序去巡视,我们返回true即可。

代码:

cpp 复制代码
class Solution {
public:
    bool find(vector<vector<int>>&grid,int n,int i,int j,int index){
        if(index==n*n) return true;     //走完了整个棋盘
        if(i<0||j<0||i>=n||j>=n||grid[i][j]!=index) return false;
        //向八个方向试探
        if(find(grid,n,i+1,j+2,index+1)) return true;
        if(find(grid,n,i+1,j-2,index+1)) return true;
        if(find(grid,n,i+2,j+1,index+1)) return true;
        if(find(grid,n,i+2,j-1,index+1)) return true;
        if(find(grid,n,i-2,j+1,index+1)) return true;
        if(find(grid,n,i-2,j-1,index+1)) return true;
        if(find(grid,n,i-1,j+2,index+1)) return true;
        if(find(grid,n,i-1,j-2,index+1)) return true;
        return false;
    }
    bool checkValidGrid(vector<vector<int>>& grid) {
        return find(grid,grid.size(),0,0,0);
    }
};
相关推荐
千纸鹤安安20 分钟前
千问Qwen-AgentWorld来了:一个语言模型搞定七大Agent场景,GPT-5.4都输了
算法
七牛开发者3 小时前
MCP 到底是什么?为什么 Agent 都想接上它
算法·aigc·agent
北域码匠6 小时前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
卷无止境8 小时前
C++ 的Eigen 库全解析
c++
卷无止境8 小时前
现代 C++特性大盘点:一门脱胎换骨的老语言
c++·后端
郝学胜_神的一滴9 小时前
CMake 27:缓存变量的特性、语法、类型与实操全解
c++·cmake
kisshyshy9 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC20 小时前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635071 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法