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;
    }
}

加油,好好努力!!!

相关推荐
cdut_suye3 分钟前
Linux工具使用指南:从apt管理、gcc编译到makefile构建与gdb调试
java·linux·运维·服务器·c++·人工智能·python
南城花随雪。10 分钟前
单片机:实现FFT快速傅里叶变换算法(附带源码)
单片机·嵌入式硬件·算法
苹果醋315 分钟前
2020重新出发,MySql基础,MySql表数据操作
java·运维·spring boot·mysql·nginx
小蜗牛慢慢爬行16 分钟前
如何在 Spring Boot 微服务中设置和管理多个数据库
java·数据库·spring boot·后端·微服务·架构·hibernate
azhou的代码园19 分钟前
基于JAVA+SpringBoot+Vue的制造装备物联及生产管理ERP系统
java·spring boot·制造
dundunmm25 分钟前
机器学习之scikit-learn(简称 sklearn)
python·算法·机器学习·scikit-learn·sklearn·分类算法
古希腊掌管学习的神26 分钟前
[机器学习]sklearn入门指南(1)
人工智能·python·算法·机器学习·sklearn
波音彬要多做27 分钟前
41 stack类与queue类
开发语言·数据结构·c++·学习·算法
Noah_aa38 分钟前
代码随想录算法训练营第五十六天 | 图 | 拓扑排序(BFS)
数据结构
wm10431 小时前
java web springboot
java·spring boot·后端