leetcode每日一题(20241205)

leetcode每日一题(20241205): 20241204的困难题还没搞明白。。然后今天还加班了回来晚,明天抽空补上

3001.捕获黑皇后需要的最少移动次数 题目描述:

bash 复制代码
现有一个下标从 1 开始的 8 x 8 棋盘,上面有 3 枚棋子。
给你 6 个整数 a 、b 、c 、d 、e 和 f ,其中:
(a, b) 表示白色车的位置。
(c, d) 表示白色象的位置。
(e, f) 表示黑皇后的位置。
假定你只能移动白色棋子,返回捕获黑皇后所需的最少移动次数。
请注意:
车可以向垂直或水平方向移动任意数量的格子,但不能跳过其他棋子。
象可以沿对角线方向移动任意数量的格子,但不能跳过其他棋子。
如果车或象能移向皇后所在的格子,则认为它们可以捕获皇后。
皇后不能移动。

这题感觉就是脑经急转弯类似的题目,我第一反应就是最多两次用车去捕捉皇后,但是也有一次就可以捕捉到的,比如车和皇后在同一列或者同一行(排除中间有象挡着车的路径的情况),还有就是象和皇后在同一对角线上(排除中间有车挡着的情况),下面看代码就是按照这个叙述来的:

java 复制代码
class Solution {
    public int minMovesToCaptureTheQueen(int a, int b, int c, int d, int e, int f) {
        if(a==e||b==f){
            if((a==e&&c==e)&&((d-b)*(d-f))<0){
                return 2;
            }
            if((b==f&&d==f)&&((c-a)*(c-e))<0){
                return 2;
            }
            return 1;
        }
        if(Math.abs(c-e)==Math.abs(d-f)){
            if(Math.abs(e-a)==Math.abs(f-b)&&Math.abs(c-a)==Math.abs(d-b)&&((a-c)*(a-e))<0)
                return 2;
            return 1;
        }
        return 2;
    }
}

加油,好好努力!!!

相关推荐
indexsunny2 小时前
互联网大厂Java求职面试实战:Spring Boot微服务与Redis缓存场景解析
java·spring boot·redis·缓存·微服务·消息队列·电商
ID_180079054732 小时前
小红书笔记详情API接口基础解析:数据结构与调用方式
数据结构·数据库·笔记
无心水2 小时前
【分布式利器:腾讯TSF】7、TSF高级部署策略全解析:蓝绿/灰度发布落地+Jenkins CI/CD集成(Java微服务实战)
java·人工智能·分布式·ci/cd·微服务·jenkins·腾讯tsf
千金裘换酒7 小时前
LeetCode 移动零元素 快慢指针
算法·leetcode·职场和发展
28岁青春痘老男孩7 小时前
JDK8+SpringBoot2.x 升级 JDK 17 + Spring Boot 3.x
java·spring boot
方璧7 小时前
限流的算法
java·开发语言
元Y亨H7 小时前
Nacos - 服务注册
java·微服务
wm10437 小时前
机器学习第二讲 KNN算法
人工智能·算法·机器学习
NAGNIP7 小时前
一文搞懂机器学习线性代数基础知识!
算法
NAGNIP7 小时前
机器学习入门概述一览
算法