Atcoder ABC339 D - Synchronized Players

news2025/1/8 3:42:48

Synchronized Players(同步的球员)

时间限制:4s 内存限制:1024MB

【原题地址】

所有图片源自Atcoder,题目译文源自脚本Atcoder Better!

点击此处跳转至原题

【问题描述】

在这里插入图片描述

【输入格式】

在这里插入图片描述
在这里插入图片描述

【输出格式】

在这里插入图片描述

【样例1】

【样例输入1】

5
....#
#..#.
.P...
..P..
....#

【样例输出1】

3

【样例说明1】

在这里插入图片描述

【样例2】

【样例输入2】

2
P#
#P

【样例输出2】

-1

【样例3】

【样例输入3】

10
..........
..........
..........
..........
....P.....
.....P....
..........
..........
..........
..........

【样例输出3】

10

【解题思路】

老汉使用到的是BFS的解题方式

本题是求两点重合的最小操作数,不能重合则输出 -1 。
设两点坐标分别为 ( i1 , j1 ) 、( i2 , j2 ),将这两个坐标用四个维度的 ( i1 , j1 , i2 , j2 ) 坐标来表示,当 i1 = i2 , j1 = j2 时,才是答案所要求的情况,初始时两点错开,只有利用好棋子遇到障碍物和边界无法继续移动的特性,才能达成目的,用 BFS 搜索最短路径,并且枚举出遇到边界和障碍物的情况下坐标的变化,最早遇到重合的情况就是答案,如果遍历了整个过程下来依然没有获取到答案,则输出 -1 。

代码注释有详细过程

【代码】

package ABC339_D_SynchronizedPlayers;

import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class Main {
	// x、y坐标移动方向
	int[] dx = { 1, 0, -1, 0 };
	int[] dy = { 0, 1, 0, -1 };
	public static void main(String[] args) {
		Scanner scan = new Scanner(System.in);
		int n = scan.nextInt();
		// 存放对应位置摆放情况
		char[][] cs = new char[n][n];
		for (int i = 0; i < n; i++) {
			cs[i] = scan.next().toCharArray();
		}
		// 头结点,用于bfs起始点
		Coord cod = new Coord();
		// 判断当前位置是否被遍历
		boolean[][][][] blank = new boolean[n][n][n][n];
		// 初始化cod
		boolean bool = true;
		cod.res = 0;
		for (int i = 0; i < n; i++) {
			for (int j = 0; j < n; j++) {
				if (cs[i][j] == 'P') {
					if (bool) {
						cod.x1 = i;
						cod.y1 = j;
						bool = false;
					} else {
						cod.x2 = i;
						cod.y2 = j;
						break;
					}
				}
			}
		}
		Queue<Coord> q = new LinkedList<Coord>();
		// 将起始点加入队列
		q.add(cod);
		Main mi = new Main();
		mi.bfs(q, blank, cs);
		scan.close();
	}

	// bfs遍历求最小操作数
	public void bfs(Queue<Coord> q, boolean[][][][] blank, char[][] cs) {
		// 存放边界n
		int n = blank.length;
		int ans = -1;
		while (!q.isEmpty()) {
			Coord cod = q.poll();
			// 当符合答案要求时,输出结果
			if (cod.x1 == cod.x2 && cod.y1 == cod.y2) {
				ans = cod.res;
				break;
			}
			for (int i = 0; i < 4; i++) {
				// 计算正常情况的下一坐标
				int xa = cod.x1 + dx[i], xb = cod.x2 + dx[i];
				int ya = cod.y1 + dy[i], yb = cod.y2 + dy[i];
				Coord coord = new Coord();
				// 操作步数等于上一步数加一
				coord.res = cod.res + 1;
				// 判断1点坐标变化
				// 未遇到边界或障碍时坐标正常更新,否则不变
				if (xa >= 0 && xa < n && ya >= 0 && ya < n && cs[xa][ya] != '#') {
					coord.x1 = xa;
					coord.y1 = ya;
				} else {
					coord.x1 = cod.x1;
					coord.y1 = cod.y1;
				}
				// 判断2点坐标变化
				// 未遇到边界或障碍时坐标正常更新,否则不变
				if (xb >= 0 && xb < n && yb >= 0 && yb < n && cs[xb][yb] != '#') {
					coord.x2 = xb;
					coord.y2 = yb;
				} else {
					coord.x2 = cod.x2;
					coord.y2 = cod.y2;
				}
				// 当下一点为空格时,添加进队列
				if (!blank[coord.x1][coord.y1][coord.x2][coord.y2]) {
					q.add(coord);
					// 标记为被访问
					blank[coord.x1][coord.y1][coord.x2][coord.y2] = true;
				}
			}
		}
		System.out.println(ans);
	}
}

class Coord {
	int x1, y1, x2, y2, res;
	public Coord() {

	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1449424.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IDEA 28 个天花板技巧

IDEA 作为Java开发工具的后起之秀&#xff0c;几乎以碾压之势把其他对手甩在了身后&#xff0c;主要原因还是归功于&#xff1a;好用&#xff1b;虽然有点重&#xff0c;但依旧瑕不掩瑜&#xff0c;内置了非常多的功能&#xff0c;大大提高了日常的开发效率&#xff0c;下面汇总…

书生浦语大模型实战营-课程笔记(2)

介绍了一下InternLm的总体情况。 InternLm是训练框架&#xff0c;Lagent是智能体框架。 这个预训练需要这么多算力&#xff0c;大模型确实花钱。 Lagent是智能体框架&#xff0c;相当于LLM的应用。 pip设置 开发机的配置 pip install transformers4.33.1 timm0.4.12 sente…

二次元自适应动态引导页

源码介绍 二次元自适应动态引导页&#xff0c;HTMLJSCSS&#xff0c;记事本修改&#xff0c;上传到服务器即可&#xff0c;也可以本地双击index.html查看效果 下载地址 https://wfr.lanzout.com/isRem1o7bfcb

山脉的个数/攀登者

题目描述 攀登者喜欢寻找各种地图&#xff0c;并且尝试攀登到最高的山峰。 地图表示为一维数组&#xff0c;数组的索引代表水平位置&#xff0c;数组的元素代表相对海拔高度。其中数组元素0代表地面。 例如&#xff1a;[0,1,2,4,3,1,0,0,1,2,3,1,2,1,0]&#xff0c;代表如下…

Vue 全组件 局部组件

一、组件定义和使用 1、全局组件 定义 <template> <div> <h1>This is a global component</h1> </div> </template> <script lang"ts"> </script> <style></style> 导入 全局组件在main.ts&#xff…

CVE-2023-41892 漏洞复现

CVE-2023-41892 开题&#xff0c;是一个RCE Thanks for installing Craft CMS! You’re looking at the index.twig template file located in your templates/ folder. Once you’re ready to start building out your site’s front end, you can replace this with someth…

猫头虎分享已解决Bug || ValueError: Unknown label type: ‘continuous‘

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通鸿蒙》 …

ESP32学习(2)——点亮LED灯

1.前期准备 开发板原理图如下&#xff1a; 可见LED灯接在了GPIO2口 那么要如何编写代码控制GPIO口的电平高低呢&#xff1f; 我们可以参考micropython的官方文档Quick reference for the ESP32 — MicroPython latest documentation 可见&#xff0c;需要导入machine包 若要…

二叉树的层序遍历II

1.题目 这道题是2024-2-15的签到题&#xff0c;题目难度为中等。 考察的知识点为BFS算法&#xff08;树的层序遍历&#xff09; 题目链接&#xff1a;二叉树的层序遍历II 给你二叉树的根节点 root &#xff0c;返回其节点值 自底向上的层序遍历 。 &#xff08;即按从叶子节…

【数据结构】二叉树的三种遍历

目录 一、数据结构 二、二叉树 三、如何遍历二叉树 一、数据结构 数据结构是计算机科学中用于组织和存储数据的方式。它定义了数据元素之间的关系以及对数据元素的操作。常见的数据结构包括数组、链表、栈、队列、树、图等。 数组是一种线性数据结构&#xff0c;它使用连续…

基于 InternLM 和 LangChain 搭建你的知识库(三)

基于 InternLM 和 LangChain 搭建你的知识库 大模型开发范式 Finetune 在大型语言模型中&#xff0c;Finetune&#xff08;微调&#xff09;是一种技术&#xff0c;用于调整预训练的模型以提高其在特定任务或数据集上的表现。这种方法通常涉及以下步骤&#xff1a; 预训练模…

跟廖雪峰老师学习Git(持续更新)

Git简介 创建版本库 第一步&#xff0c;创建一个新目录 第二步&#xff0c;通过git init变成Git可以管理的仓库 把文件添加到文本库&#xff0c;不要使用Windows自带的记事本&#xff01; 我用的是VS code 创建readme.txt 放入库中 commit可以一次提交很多文件&#xff0…

JVM对象创建与内存分配机制深度剖析

对象的创建 对象创建的主要流程: 1.类加载检查 虚拟机遇到一条new指令时&#xff0c;首先将去检查这个指令的参数是否能在常量池中定位到一个类的符号引用&#xff0c;并且检查这个符号引用代表的类是否已被加载、解析和初始化过。如果没有&#xff0c;那必须先执行相应的类…

Java集合框架(包装类、泛型)

前言&#xff1a; 本篇文章我们来讲解Java中的集合框架&#xff0c;就相当于车轮子。Java是面向对象的语言&#xff0c;所以相对于C语言有自身优势&#xff0c;就比如现成的数据结构&#xff08;比如栈&#xff0c;队列&#xff0c;堆等&#xff09;。Java的集合框架大家也不用…

代码随想录 Leetcode135. 分发糖果

题目&#xff1a; 代码(首刷看解析 2024年2月15日&#xff09;&#xff1a; class Solution { public:int candy(vector<int>& ratings) {vector<int> left(ratings.size(), 1);vector<int> right(ratings.size(), 1);for (int i 1; i < ratings.si…

[C#] 如何调用Python脚本程序

为什么需要C#调用python&#xff1f; 有以下几个原因需要C#调用Python&#xff1a; Python拥有丰富的生态系统&#xff1a;Python有很多强大的第三方库和工具&#xff0c;可以用于数据科学、机器学习、自然语言处理等领域。通过C#调用Python&#xff0c;可以利用Python的生态系…

代码随想录刷题笔记 DAY 26 | 组合总和 No.39 | 组合求和 II No.40 | 分割回文串 No.131

文章目录 Day 2501. 组合总和&#xff08;No. 39&#xff09;1.1 题目1.2 笔记1.3 代码 02. 组合求和 II&#xff08;No. 40&#xff09;2.1 题目2.2 笔记2.3 代码 03. 分割回文串&#xff08;No. 131&#xff09;3.1 题目3.2 笔记3.3 代码 Day 25 01. 组合总和&#xff08;No…

Leetcode 115 不同的子序列

题意理解&#xff1a; 给你两个字符串 s 和 t &#xff0c;统计并返回在 s 的 子序列 中 t 出现的个数&#xff0c;结果需要对 109 7 取模。 即此题可以理解为&#xff1a;从s中删除元素去构造t,有多少种方法 或者也可以理解为&#xff1a;s中按顺序取t,有多少个 则一定有s和t…

FreeRTOS 队列管理

概览 基于 FreeRTOS 的应用程序由一组独立的任务构成——每个任务都是具有独立权 限的小程序。这些独立的任务之间很可能会通过相互通信以提供有用的系统功能。 FreeRTOS 中所有的通信与同步机制都是基于队列实现的。 本章期望让读者了解以下事情   如何创建一个队列   …

如何将字体添加到 ONLYOFFICE 文档服务器 8.0

作者&#xff1a;VincentYoung 阅读本文&#xff0c;了解如何为自己的在线办公软件 ONLYOFFICE 文档服务器的字体库添加字体 ONLYOFFICE 文档是什么 ONLYOFFICE 文档是一个功能强大的文档编辑器&#xff0c;支持处理文本文档、电子表格、演示文稿、可填写表单、PDF 和电子书…