【题解】2596. 检查骑士巡视方案

题解:

cpp 复制代码
class Solution 
{
    int n,m;
    bool st[100][100];
    int flag;
    int dx[8]={-1,-2,-2,-1,1,2,2,1};
    int dy[8]={-2,-1,1,2,2,1,-1,-2};
public:
    bool checkValidGrid(vector<vector<int>>& grid) 
    {
        m = grid.size();
        n = grid[0].size();
        dfs(grid,0,0,0);
        return flag;
    }
    void dfs(vector<vector<int>>& grid,int i,int j,int u)
    {
        st[i][j] = true;
        if(grid[i][j] != u) return;

        if(grid[i][j] == n * m -1)//遍历完所有数组了就可以返回了
        {
            flag = true;
            return;
        }
        for(int k=0;k<8;k++)
        {
            int x=i+dx[k];
            int y=j+dy[k];
            if(x>=0 && x<n && y>=0 && y<m && !st[x][y])
            {
                st[x][y]=true;
                dfs(grid,x,y,u+1);
                st[x][y]=false;
            }

        }
    }

};
相关推荐
CoderCodingNo几秒前
【GESP】C++一级真题 luogu-B4410 [GESP202509 一级] 金字塔
开发语言·c++
超级大福宝1 分钟前
C++中1 << 31 - 1相当于INT_MAX吗?
c语言·c++
亭台8 分钟前
【Matlab笔记_23】MATLAB的工具包m_map的m_image和m_pcolor区别
笔记·算法·matlab
李玮豪Jimmy9 分钟前
Day39:动态规划part12(115.不同的子序列、583.两个字符串的删除操作、72.编辑距离)
算法·动态规划
alibli14 分钟前
一文学会设计模式之结构型模式及最佳实现
c++·设计模式
A7bert77715 分钟前
【YOLOv5seg部署RK3588】模型训练→转换RKNN→开发板部署
linux·c++·人工智能·深度学习·yolo·目标检测
历程里程碑1 小时前
C++ 10 模板进阶:参数特化与分离编译解析
c语言·开发语言·数据结构·c++·算法
老秦包你会1 小时前
C++进阶------智能指针和特殊类设计方式
开发语言·c++
星辞树1 小时前
从 In-context Learning 到 RLHF:大语言模型的范式跃迁
算法
再__努力1点1 小时前
【68】颜色直方图详解与Python实现
开发语言·图像处理·人工智能·python·算法·计算机视觉