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 中的所有整数 互不相同
相关推荐
Happy_Traveller7 小时前
三角形的最大周长(976)
数据结构·算法·leetcode
咒法师无翅鱼8 小时前
【leetcode详解】T598 区间加法
算法·leetcode·职场和发展
kcwqxx9 小时前
day37|完全背包基础+leetcode 518.零钱兑换II ,377.组合总和II
c++·算法·leetcode·动态规划
sjsjs1112 小时前
【数据结构-字典树】力扣14. 最长公共前缀
数据结构·leetcode
JNU freshman13 小时前
力扣第435场周赛讲解
算法·leetcode·蓝桥杯
pursuit_csdn16 小时前
力扣 347. 前 K 个高频元素
算法·leetcode
makabaka_T_T16 小时前
25寒假算法刷题 | Day1 | LeetCode 240. 搜索二维矩阵 II,148. 排序链表
数据结构·c++·算法·leetcode·链表·矩阵
余辉zmh19 小时前
【贪心算法篇】:“贪心”之旅--算法练习题中的智慧与策略(二)
c++·算法·leetcode·贪心算法
余辉zmh19 小时前
【贪心算法篇】:“贪心”之旅--算法练习题中的智慧与策略(一)
c++·算法·leetcode·贪心算法
taoyong00119 小时前
代码随想录算法训练营第三十七天-动态规划-完全背包-377. 组合总和 Ⅳ
c++·算法·leetcode·动态规划