2023-09-13力扣每日一题

链接:

2596. 检查骑士巡视方案

题意

骑士走日字,就是absx=2 absy=1absx=1 absy=2

一共就那么点格子,暴力搜八个方向也行

先用数组存每一步对应的位置,然后判断相邻两个位置是否符合日字

我直接用absx+absy==3就过了,大概是不存在一个有单方向走三格案例或不存在这样的案例??

实际代码:

c++ 复制代码
#include<bits/stdc++.h>
using namespace std;
bool checkValidGrid(vector<vector<int>>& grid)
{
	if(grid[0][0]!=0) return false;
	
	typedef pair<int,int> PII;
	int lg=grid.size();
    vector<PII>Path(lg*lg+7);
    
    for(int i=0;i<lg;i++)
    {
    	for(int j=0;j<lg;j++)
    	{
    		Path[grid[i][j]].first=i;
    		Path[grid[i][j]].second=j;
		}
	}
	
	for(int i=0;i<lg*lg-1;i++)
	{
		int absx=abs(Path[i].first-Path[i+1].first);
		int absy=abs(Path[i].second-Path[i+1].second);
		//if(absx>=3||absy>=3) return false;
		if(absx+absy==3) continue;
		return false;
	}
	return true;
}

限制:

  • n == grid.length == grid[i].length
  • 3 <= n <= 7
  • 0 <= grid[row][col] < n * n
  • grid 中的所有整数 互不相同
相关推荐
飞川撸码2 小时前
【LeetCode 热题100】网格路径类 DP 系列题:不同路径 & 最小路径和(力扣62 / 64 )(Go语言版)
算法·leetcode·golang·动态规划
_Itachi__10 小时前
LeetCode 热题 100 74. 搜索二维矩阵
算法·leetcode·矩阵
chao_78911 小时前
链表题解——两两交换链表中的节点【LeetCode】
数据结构·python·leetcode·链表
编程绿豆侠13 小时前
力扣HOT100之多维动态规划:1143. 最长公共子序列
算法·leetcode·动态规划
dying_man1 天前
LeetCode--24.两两交换链表中的结点
算法·leetcode
yours_Gabriel1 天前
【力扣】2434.使用机器人打印字典序最小的字符串
算法·leetcode·贪心算法
GGBondlctrl1 天前
【leetcode】递归,回溯思想 + 巧妙解法-解决“N皇后”,以及“解数独”题目
算法·leetcode·n皇后·有效的数独·解数独·映射思想·数学思想