LeetCode每日一题:1222. 可以攻击国王的皇后(2023.9.14 C++)

news/2024/7/23 17:07:59 标签: leetcode, 算法, c++

目录

1222. 可以攻击国王的皇后

题目描述:

实现代码与解析:

模拟

原理思路:


1222. 可以攻击国王的皇后

题目描述:

在一个 8x8 的棋盘上,放置着若干「黑皇后」和一个「白国王」。

给定一个由整数坐标组成的数组 queens ,表示黑皇后的位置;以及一对坐标 king ,表示白国王的位置,返回所有可以攻击国王的皇后的坐标(任意顺序)。

示例 1:

输入:queens = [[0,1],[1,0],[4,0],[0,4],[3,3],[2,4]], king = [0,0]
输出:[[0,1],[1,0],[3,3]]
解释: 
[0,1] 的皇后可以攻击到国王,因为他们在同一行上。 
[1,0] 的皇后可以攻击到国王,因为他们在同一列上。 
[3,3] 的皇后可以攻击到国王,因为他们在同一条对角线上。 
[0,4] 的皇后无法攻击到国王,因为她被位于 [0,1] 的皇后挡住了。 
[4,0] 的皇后无法攻击到国王,因为她被位于 [1,0] 的皇后挡住了。 
[2,4] 的皇后无法攻击到国王,因为她和国王不在同一行/列/对角线上。

示例 2:

输入:queens = [[0,0],[1,1],[2,2],[3,4],[3,5],[4,4],[4,5]], king = [3,3]
输出:[[2,2],[3,4],[4,4]]

示例 3:

输入:queens = [[5,6],[7,7],[2,1],[0,7],[1,6],[5,1],[3,7],[0,3],[4,0],[1,2],[6,3],[5,0],[0,4],[2,2],[1,1],[6,4],[5,4],[0,0],[2,6],[4,5],[5,2],[1,4],[7,5],[2,3],[0,5],[4,2],[1,0],[2,7],[0,1],[4,6],[6,1],[0,6],[4,3],[1,7]], king = [3,4]
输出:[[2,3],[1,4],[1,6],[3,7],[4,3],[5,4],[4,5]]

提示:

  • 1 <= queens.length <= 63
  • queens[i].length == 2
  • 0 <= queens[i][j] < 8
  • king.length == 2
  • 0 <= king[0], king[1] < 8
  • 一个棋盘格上最多只能放置一枚棋子。

实现代码与解析:

模拟

class Solution {
public:
    vector<vector<int>> queensAttacktheKing(vector<vector<int>>& queens, vector<int>& king) {
        
        bool isQueue[8][8] = {false};
        for (auto t: queens) {
            int x = t[0], y = t[1];
            isQueue[x][y] = true;
        }

        vector<vector<int>> res;
        int dx[8] = {-1, -1, -1, 0, 0, 1, 1, 1};
        int dy[8] = {1, 0, -1, 1, -1, 1, 0, -1};
        for (int i = 0; i < 8; i++)
        {
            int x = king[0] + dx[i], y = king[1] + dy[i]; // 国王当前位置
            while (x >= 0 && x < 8 && y >= 0 && y < 8)
            {
                if (isQueue[x][y])
                {
                    res.push_back({x, y});
                    break;
                }
                x += dx[i];
                y += dy[i];
            }
        }
        return res;
    }
}

原理思路:

  1. 首先,代码定义了一个二维布尔数组 isQueue,用于表示棋盘上的每个位置是否有皇后。数组的大小是8x8,初始值都设置为 false

  2. 接下来,通过一个循环遍历输入参数 queens,其中 queens 是一个表示皇后位置的二维整数向量。循环将每个皇后的位置标记在 isQueue 数组中,将相应位置设为 true

  3. 创建一个空的二维整数向量 res,用于存储可以攻击到国王的皇后的位置。

  4. 定义两个一维整数数组 dxdy,它们分别表示了8个可能的方向。dx 用于水平方向的偏移量,dy 用于垂直方向的偏移量。这两个数组用于确定每个方向上国王下一步可能的位置。

  5. 通过一个循环遍历8个可能的方向。在每个方向上,从国王的当前位置开始,通过逐步增加 xy 的值来移动。在每一步中,代码检查该位置是否有皇后(通过检查 isQueue[x][y] 的值),如果有皇后,则将该位置添加到 res 中,并且终止该方向的移动(因为皇后可以阻止进一步移动)。

  6. 最后,返回存储着可以攻击到国王的皇后位置的 res 二维整数向量。

        核心思想是遍历8个可能的方向,从国王的位置出发,检查每个方向上是否有皇后,如果有就将其位置添加到结果中。这样,最终得到的 res 就包含了可以攻击到国王的皇后的位置坐标。


http://www.niftyadmin.cn/n/5026242.html

相关文章

【excel密码】excel文件加密方法总结:

想要给Excel文件进行加密&#xff0c;方法有很多&#xff0c;今天分享三种Excel加密方法给大家。 打开密码 设置了打开密码的excel文件&#xff0c;打开文件就会提示输入密码才能打开excel文件&#xff0c;只有输入了正确的密码才能打开并且编辑文件&#xff0c;如果密码错误…

Postman使用_接口请求

文章目录 版本说明注册登录创建工作空间创建Collection、Folder和Request接口请求参数Get请求Post请求 版本说明 我的Postman版本是Windows桌面端Version 10.16.0&#xff0c;最新版下载 。 基于该版本进行调试和说明&#xff0c;如果版本不一致&#xff0c;会有点差异&#…

Boostrap对HTML的表格的设计和优化

目录 01-Bootstrap的默认表格风格02-没有边线-边界的表格03-行与行的背景颜色交替变换(条纹样式)04-给表格加上边框效果05-鼠标移到行上时该行的颜色加深06-把表格的padding值缩减一半,使表格看起来更紧凑07-为表格的行或单元格设置颜色 01-Bootstrap的默认表格风格 Bootstrap…

Ceph入门到精通-进入维保模式设置命令set noout

设置 noout、norecover、norebalance、nobackfill、nodown 和 pause 标志。在具有客户端密钥环的节点上运行以下命令&#xff1a;例如&#xff0c;Ceph Monitor 或 OpenStack 控制器节点&#xff1a; [rootmon ~]# ceph osd set noout [rootmon ~]# ceph osd set norecover [ro…

ES6 特性

一、ES6 1.1 ES6 概念 1.1.1 什么是 ES ES 全称 EcmaScript 是脚本语言的规范JavaScript 是 EcmaScript 的一种实现ES 新特性就是指 JavaScript 的新特性 1.1.2 为什么要使用 ES 语法简单&#xff0c;功能丰富框架开发应用前端开发职位要求 1.1.3 为什么要学习 ES6 ES6 …

macOS 12 Monterey:一次全新的跨设备协作体验

macOS 12 Monterey是苹果公司的一次重大突破&#xff0c;它打破了设备间的壁垒&#xff0c;将不同设备无缝地连接在一起&#xff0c;极大地提升了用户的工作效率和娱乐体验。Monterey带来了通用控制、AirPlay、捷径等新功能&#xff0c;以及一些实用的新小功能。 安装&#xf…

设计模式解析之模板方法模式:设计灵活可扩展的算法框架

目录 1. 引言2. 概要2.1 概念2.2 结构2.3 类图2.4 工作流程 3. 应用场景3.1 适用情况&#xff1a;3.2 常见例子&#xff1a; 4. 代码衍化过程初版&#xff1a;甲乙学生都抄试卷第二版&#xff1a;提炼代码第三版&#xff1a;抽象出算法骨架第四版&#xff1a;模板方法变化过程总…

神经网络-Unet网络

文章目录 前言1.seq2seq 编码后解码2. 网络结构3.特征融合4. 前言 Unet用来做小目标语义分割。 优点&#xff1a;网络结构非常简单。 大纲目录 2016年特别火&#xff0c;在细胞领域做分割特别好。 1.seq2seq 编码后解码 2. 网络结构 几个卷积层&#xff0c;越来越扁&#x…