BFS专题8 中国象棋-马-无障碍
题目:
样例:
|
|

思路:
单纯的BFS走一遍即可,只是方向坐标的移动变化,需要变化一下。
代码详解如下:
#include <iostream>
#include <vector>
#include <queue>
#include <cstring>
#include <algorithm>
#include <unordered_map>
#define endl '\n'
#define x first
#define y second
#define mk make_pair
#define YES puts("YES")
#define NO puts("NO")
#define umap unordered_map
#define All(x) x.begin(),x.end()
#pragma GCC optimize(3,"Ofast","inline")
#define IOS std::ios::sync_with_stdio(false),cin.tie(0), cout.tie(0)
using namespace std;
const int N = 500;
using PII = pair<int,int>;
// 象棋走动的方向
int dx[8] = {2,2,-2,-2,1,-1,1,-1};
int dy[8] = {1,-1,1,-1,2,2,-2,-2};int g[N][N],n,m; // 象棋棋盘以及大小
bool st[N][N]; // 标记是否走过当前坐标
PII now; // 当前象棋坐标inline bool isRun(int &x,int &y)
{return (x > 0 && x <= n && y > 0 && y <= m && !st[x][y]);
}inline void BFS()
{// 初始化坐标所对应的最少步数memset(g,-1,sizeof g);g[now.x][now.y] = 0; // 初始化起点步数为 0int step = 0;queue<PII>q;q.emplace(now);while(q.size()){int sz = q.size();while(sz--){PII tem = q.front();q.pop(); // 取出当前坐标st[tem.x][tem.y] = true; // 标记当前坐标g[tem.x][tem.y] = step; // 存储当前坐标所对应的最少步数// 尝试往各个方向坐标走动for(int i = 0;i < 8;++i){int bx = tem.x + dx[i];int by = tem.y + dy[i];if(isRun(bx,by)){// 如果符合走动条件// 存储下一个走动的坐标,并标记q.emplace(mk(bx,by));st[bx][by] = true;}}}++step;}
}// 打印棋盘各个坐标所对应的最少步数
inline void PrintG()
{for(int i = 1;i <= n;++i){for(int j = 1;j <= m;++j){if(j > 1) cout << ' '; // 控制输入格式cout << g[i][j];}cout << endl;}
}inline void solve()
{cin >> n >> m >> now.x >> now.y; // 输入所对应的信息BFS(); // BFS 搜索各个坐标所对应的最少步数PrintG(); // 输出答案
}int main()
{
// freopen("a.txt", "r", stdin);IOS;int _t = 1;
// cin >> _t;while (_t--){solve();}return 0;
}
最后提交:
相关文章:
BFS专题8 中国象棋-马-无障碍
题目: 样例: 输入 3 3 2 1 输出 3 2 1 0 -1 4 3 2 1 思路: 单纯的BFS走一遍即可,只是方向坐标的移动变化,需要变化一下。 代码详解如下: #include <iostream> #include <vector> #include…...
R语言中fread怎么使用?
R语言中 fread 怎么用? 今天分享的笔记内容是数据读取神器fread,速度嘎嘎快。在R语言中,fread函数是data.table包中的一个功能强大的数据读取函数,可以用于快速读取大型数据文件,它比基本的read.table和read.csv函数更…...
element-plus 表格-自定义样式实现2
<template><h2>表格修改样式利用属性修改</h2><h3>row-style 行样式</h3><h3>row-style header-row-style 不能改背景色</h3><h3>cell-style header-cell-style能改背景色</h3><el-tableref"tableRef":dat…...
Mysql中的RR 隔离级别,到底有没有解决幻读问题
Mysql 中的 RR 事务隔离级别,在特定的情况下会出现幻读的问题。所谓的幻读,表示在同一个事务中的两次相同条件的查询得到的数据条数不一样。 在 RR 级别下,什么情况下会出现幻读 这样一种情况,在事务 1 里面通过 update 语句触发当…...
Visual Studio 2022下载安装的详细步骤-----C语言编辑器
目录 一、介绍 (一)和其他软件的区别 (二)介绍编写C语言的编辑器类型 二、下载安装 三、创建与运行第一个C语言程序 (一)创建项目 (二)新建文件 (三)…...
数据可视化与GraphQL:利用Apollo创建仪表盘
前言 「作者主页」:雪碧有白泡泡 「个人网站」:雪碧的个人网站 「推荐专栏」: ★java一站式服务 ★ ★ React从入门到精通★ ★前端炫酷代码分享 ★ ★ 从0到英雄,vue成神之路★ ★ uniapp-从构建到提升★ ★ 从0到英雄ÿ…...
Java中静态常量和枚举类的区别
在项目中我们有时候会使用常量、静态常量以及枚举,那么他们有什么区别呢?我们先看几个例子: 若依框架中使用的常量: /** 正常状态 */public static final String NORMAL "0";/** 异常状态 */public static final Stri…...
GenericWriteAheadSink每次checkpoint后事务是否必须成功
背景 GenericWriteAheadSink原理是把接收记录按照检查点进行分段,每个到来的记录都放到对应的分段中,这些分段内的记录是作为算子状态的形式存储和故障恢复的,对于每个分段内的记录列表,flink会在收到检查点完成的通知时把他们都…...
[深入浅出AutoSAR] SWC 设计与应用
依AutoSAR及经验辛苦整理,原创保护,禁止转载。 专栏 《深入浅出AutoSAR》 全文 3100 字, 包含 1. SWC 概念 2. 数据类型(Datatype) 3. 端口(Port) 4. 端口接口(Portinterface&…...
【Ubuntu系统搭建STM32开发环境(国内镜像全程快速配置)】
源于本人失败的经历苦心研究 虚拟机安装ubuntu换源VScode安装安装Java环境安装cubemx安装 arm-Linux-gcc安装gdb server安装OpenOCD 虚拟机安装ubuntu 系统镜像可以在阿里云镜像站且下载速度很快。 选择安装的版本。 我选择的是:ubuntu-22.10-desktop-amd64.iso。…...
Java 中的 Default 关键字
default 关键字:是在 Java 8 中引入的新概念,也可称为 Virtual extension methods——虚拟扩展方法与public、private等都属于修饰符关键字,与其它两个关键字不同之处在于default关键字大部分都用于修饰接口。 default 修饰方法时只能在接口…...
AdaBoost:增强机器学习的力量
一、介绍 机器学习已成为现代技术的基石,为从推荐系统到自动驾驶汽车的一切提供动力。在众多机器学习算法中,AdaBoost(自适应增强的缩写)作为一种强大的集成方法脱颖而出,为该领域的成功做出了重大贡献。AdaBoost 是一…...
c++踩坑点,类型转换
std::string转换到PVOID std::string转换到PVOID的方式如下 这样的话成功转换 “const char *” 类型的实参与 “WCHAR *” “const char *” 类型的实参与 “WCHAR *” 类型的形参不兼容 可以看到这种报错,可以直接强转如下: 但是在我们这里不适…...
mysql—面试50题—1
注:面试50题将分为5个部分,每部分10题 一、查询数据 学生表 Student create table Student(SId varchar(10),Sname varchar(10),Sage datetime,Ssex varchar(10)); insert into Student values(01 , 赵雷 , 1990-01-01 , 男); insert into Student …...
vue解决报错Unable to preventDefault inside passive event listener invocation.
"Unable to preventDefault inside passive event listener invocation"是浏览器开发中的一个警告信息。这个警告通常出现在使用passive事件监听器时,当在事件处理函数中调用preventDefault()方法时会引发该警告。 在传统的事件监听模型中,当…...
实际项目中最常用的设计模式
在软件开发领域,设计模式是一种经过验证的通用解决方案,用于解决各种常见问题。它们有助于提高代码的可维护性、可扩展性和可重用性。虽然有许多不同的设计模式,但以下是实际项目中最常用的一些: 1. 单例模式 (Singleton Pattern) 单例模式确保一个类只有一个实例,并提供…...
使用stream流根据对象属性对复杂list对象去重
日常开发中,我们可能会遇到这样一种情况,需要对数据库查询出来的数据进行一个二次处理,从而达到我们需要的数据结构。stream流正是java8提供的对复杂list操作方便工具。 我们先介绍如何使用stream流根据对象属性对复杂list对象去重࿰…...
vue3脚手架搭建
一.安装 vue3.0 脚手架 如果之前安装了2.0的脚手架,要先卸载掉,输入: npm uninstall vue-cli -g 进行全局卸载 1.安装node.js(npm) node.js:简单的说 Node.js 就是运行在服务端的 JavaScript。Node.js 是…...
MongoDB 未授权访问漏洞
简介 MongoDB是一个基于分布式文件存储的数据库,是一个介于关系数据库和非关系数据库之间的产品,它的特点是高性能、易部署、易使用,存储数据非常方便,默认情况下是没有认证的这就导致不熟悉它的研发人员部署后没有做访问控制导致…...
花5分钟学习机器学习基础知识
一、什么是机器学习 机器学习的目的是让机器学习,而不是执行预设的算法。 机器学习适用于难以制定规则的问题,如垃圾邮件识别、图像识别。 机器学习模拟人类学习过程:从样本中学习归纳总结,形成模型,然后应用模型完成任务。 机器学习需要大量样本数据和计算能力支持。当前数…...
用Python+代理IP池模拟真实用户,手把手教你实现抖音直播间自动互动脚本
Python自动化直播间互动技术解析 在当今数字营销领域,直播平台已成为品牌与用户互动的重要渠道。对于开发者而言,理解如何通过技术手段实现自动化互动不仅具有学习价值,也能为数据分析提供支持。本文将深入探讨基于Python的直播间自动化技术实…...
投稿不“掉坑”:百考通AI期刊论文写作,如何为你的科研减负?
智能工具填平格式与规范的鸿沟,让你的研究价值被真正看见 深夜的实验室里,电脑屏幕上闪烁的,是你修改了第十二遍的论文草稿。引用格式又出错了?研究方法描述不够清晰?语言表达不够学术化?你已经记不清这是第…...
告别投稿“内耗”:百考通AI如何将SCI与核心论文的写作门槛“拉平”
如果你曾将心血之作投向期刊,却只收到一封封格式化的退稿信;如果你的邮箱里堆满了“未通过初审”、“不符合本刊要求”的邮件,或许该停下来想想:问题真的全在研究内容本身吗?事实上,许多优质的科研工作&…...
Unity网络开发革命:Netcode for GameObjects完整入门指南
Unity网络开发革命:Netcode for GameObjects完整入门指南 【免费下载链接】com.unity.netcode.gameobjects Netcode for GameObjects is a high-level netcode SDK that provides networking capabilities to GameObject/MonoBehaviour workflows within Unity and …...
DolphinScheduler 3.x 集成 DataX 保姆级教程:从环境变量到HDFS权限,一次搞定所有坑
DolphinScheduler 3.x 与 DataX 深度集成实战:权限控制与性能调优全解析 在数据工程领域,ETL 流程的稳定性和效率直接影响着数据仓库的质量和时效性。DolphinScheduler 作为一款开源的分布式工作流调度系统,与阿里巴巴开源的 DataX 数据同步工…...
回归显见:在亚马逊,为何“最简单、最本质”的价值是抵御复杂化陷阱的终极武器
天主教会从“律法教师”到“福音教师”的定位回归,揭示了一个对抗“内部复杂化”的战略真理:当组织因扩张或竞争陷入角色混乱时,最有效的解法不是创造更复杂的新定义,而是回到那个最简单、最本质、最显见、且具有永恒价值的核心身…...
【C# 14原生AOT实战白皮书】:3大成本削减杠杆+27%内存降幅实测数据,Dify客户端部署不再烧钱
第一章:C# 14 原生 AOT 部署 Dify 客户端的成本控制全景图C# 14 原生 AOT(Ahead-of-Time)编译能力显著降低了 Dify 客户端在边缘设备与轻量级容器环境中的部署开销。通过消除运行时 JIT 编译、减少内存占用及启动延迟,AOT 可将客户…...
文档解析准确率从81.6%→99.2%:Dify v0.8.5+自定义Chunker调优全流程,仅限内部技术团队验证的7个关键参数
第一章:文档解析准确率从81.6%→99.2%:Dify v0.8.5自定义Chunker调优全流程,仅限内部技术团队验证的7个关键参数 在 Dify v0.8.5 版本中,原生文档解析器对多格式混合文档(含 PDF 表格嵌套、Markdown 代码块与中文段落混…...
避开那些坑:在Windows/Mac上成功安装scikit-survival 0.20+的完整指南
避开那些坑:在Windows/Mac上成功安装scikit-survival 0.20的完整指南 生存分析在医疗、金融和工程领域有着广泛应用,而scikit-survival作为Python生态中的重要工具,却让不少开发者在安装阶段就栽了跟头。特别是当系统环境复杂或依赖项版本冲突…...
从随机数据到平滑曲线:用PCHIP算法在MATLAB中玩转数据插值(保姆级教程)
从随机数据到平滑曲线:用PCHIP算法在MATLAB中玩转数据插值(保姆级教程) 刚接触数据分析时,最让人头疼的莫过于拿到一组杂乱无章的实验数据,却要呈现出一条专业、平滑的曲线。记得我第一次处理传感器采集的振动数据时&a…...
