力扣2596

题目来源

示例 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 中的所有整数 互不相同

核心思想:不管怎么走下一步,开始位置和下一步的位置的横坐标和纵坐标的差的积的绝对值为2,如果不为2的话,那么就说明走错了,返回false

复制代码
if(grid[0][0]!=0){
        return false;
    }

题目要求从左上角开始,那么首先要有一个判断骑士是否从左上角开始的语句

复制代码
 int n = gridSize;
   int arr[n*n][2];
   for(int i = 0;i<n;i++){
       for(int j = 0;j<n;j++){
           arr[grid[i][j]][0] = i;
           arr[grid[i][j]][1] = j;
       }
   }

重新定义了一个数组arr,下标表示第几次跳到的格子,里面所对应的是(x,y)坐标

复制代码
for(int i = 1;i<n*n;i++){
       int x = abs(arr[i][0] - arr[i-1][0]);
       int y = abs(arr[i][1] - arr[i-1][1]);
       if(x*y!=2){
           return false;
       }

   }
   return true;

循环遍历上面定义的数组arr,由上述的arr数组的意义所知,arr[i][0]表示的是第i次被跳到的格子所对应的x坐标,那么arr[i-1][0]就是第i-1次跳到的格子的x坐标,以此算出x,y的差距,然后相乘,如果相乘不等于2的话,说明这个跳的格子有问题,就返回false,将所有坐标都遍历完之后,没有发现不匹配的格子,那么就返回true

完整代码:

复制代码
bool checkValidGrid(int** grid, int gridSize, int* gridColSize){
    
    if(grid[0][0]!=0){
        return false;
    }

   int n = gridSize;
   int arr[n*n][2];
   for(int i = 0;i<n;i++){
       for(int j = 0;j<n;j++){
           arr[grid[i][j]][0] = i;
           arr[grid[i][j]][1] = j;
       }
   }
   for(int i = 1;i<n*n;i++){
       int x = abs(arr[i][0] - arr[i-1][0]);
       int y = abs(arr[i][1] - arr[i-1][1]);
       if(x*y!=2){
           return false;
       }

   }
   return true;

}
相关推荐
jiayong234 分钟前
Spring IOC 与 AOP 核心原理深度解析
java·spring·log4j
ShiMetaPi10 分钟前
SAM(通用图像分割基础模型)丨基于BM1684X模型部署指南
人工智能·算法·ai·开源·bm1684x·算力盒子
前端小白在前进12 分钟前
力扣刷题:无重复字符的最长子串
算法·leetcode·职场和发展
卿雪12 分钟前
Redis 线程模型:Redis为什么这么快?Redis为什么引入多线程?
java·数据库·redis·sql·mysql·缓存·golang
小小的橙菜吖!14 分钟前
联合体的学习
学习·算法
lkbhua莱克瓦2418 分钟前
IO流练习(修改文件中的数据)
java·windows·学习方法·io流·java练习题·io流练习
老华带你飞23 分钟前
汽车销售|汽车报价|基于Java汽车销售系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot·后端·汽车
西岭千秋雪_34 分钟前
MySQL集群搭建
java·数据库·分布式·mysql
Xing_ke30935 分钟前
3D点云分割与检测(后续更新)
算法·3d点云
4311媒体网36 分钟前
C语言实现简单的二分查找算法
c语言·开发语言·算法