【力扣每日一题】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);
    }
};
相关推荐
晚风(●•σ )7 分钟前
C++语言程序设计——11 C语言风格输入/输出函数
c语言·开发语言·c++
恒者走天下1 小时前
秋招落定,拿到满意的offer,怎么提高自己实际的开发能力,更好的融入团队
c++
做怪小疯子1 小时前
LeetCode 热题 100——矩阵——旋转图像
算法·leetcode·矩阵
努力学习的小廉1 小时前
我爱学算法之—— BFS之最短路径问题
算法·宽度优先
天若有情6732 小时前
【c++】手撸C++ Promise:从零实现通用异步回调组件,支持链式调用+异常安全
开发语言·前端·javascript·c++·promise
高山上有一只小老虎2 小时前
构造A+B
java·算法
学困昇2 小时前
C++中的异常
android·java·c++
木头左2 小时前
缺失值插补策略比较线性回归vs.相邻填充在LSTM输入层的性能差异分析
算法·线性回归·lstm
sin_hielo2 小时前
leetcode 2435
数据结构·算法·leetcode
合作小小程序员小小店3 小时前
桌面安全开发,桌面二进制%恶意行为拦截查杀%系统安全开发3.0,基于c/c++语言,mfc,win32,ring3,dll,hook,inject,无数据库
c语言·开发语言·c++·安全·系统安全