【力扣每日一题】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);
    }
};
相关推荐
小黄人软件1 分钟前
C++读写编辑CSV文件示例源码 用于数据导入导出,比Excel好使
开发语言·c++·excel
郭涤生8 分钟前
C++各个版本的性能和安全性总结
开发语言·c++
hoiii18722 分钟前
基于栅格法的机器人工作空间划分系统
数据结构·机器人
DragonnAi25 分钟前
猫咪如厕检测与分类识别系统系列【十四】 项目结构重新整理-即将开源完整算法
算法·开源
机器视觉_Explorer43 分钟前
【halcon】编程技巧:鼠标擦除
图像处理·人工智能·深度学习·算法·视觉检测
wljy11 小时前
二、静态库的制作和使用
linux·c语言·开发语言·c++
道剑剑非道1 小时前
FFmpeg 6.0 实战:用 C++ 封装摄像头采集与 RTSP 推流
开发语言·c++·ffmpeg
灵智实验室2 小时前
PX4状态估计技术EKF2详解(二):EKF2 误差状态动力学与协方差传播
算法·无人机·px 4
米粒12 小时前
力扣算法刷题 Day 64 Floyd算法 & A* 算法 & 总结篇
算法·leetcode·职场和发展
光电笑映2 小时前
从环境变量到进程虚拟地址空间——Linux 内存管理的底层脉络
linux·服务器·c++·c