55-蓝桥部队(蓝桥杯)
创始人
2025-06-01 02:59:22
0

题目描述

小明是蓝桥部队的长官,他的班上有 N 名军人和 1 名军师。

这天,N 名军人在操场上站成一排,起初编号为 i 的军人站在第 i 列。

作为长官,小明可以对军人和军师下达 M 条命令,命令有两种类型,格式如下:

  • 1 x y,让军人 x 所在列的所有人作为一个整体移动到和军人 y 所在列的后面,使两列合并为一列。

  • 2 x y,询问军师军人 x 和军人 y 是否站在同一列。若是,则军师要回应小明 x,y 之间有多少人,否则军师要回应 −1。

你就是小明的军师,请你回答小明的每个询问。

输入描述

输入第 11 行包含两个正整数 N,M,分别表示军人的数量和小明的命令条数。

第2∼M+1 行每行表示一条命令。

2≤N≤105,1≤M≤3×105,1≤x,y≤N。

输出描述

对于每个询问,输出一行表示答案。

输入输出样例

示例 1

输入
3 5
2 1 2
1 2 1 
2 1 2
1 1 3
2 2 3 
输出
-1
0
1

运行限制

  • 最大运行时间:3s

  • 最大运行内存: 256M

源码:

import java.util.Scanner;public class 蓝桥部队 {static int[] parent;static int[] rank;static int[] d;public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int m = scanner.nextInt();//初始化size,d,p数组rank = new int[n+1];parent = new int[n+1];d = new int[n+1];for (int i = 1; i <= n; i++) {rank[i] = 1;parent[i] = i;d[i] = 0;}//读取操作for (int i = 0; i < m; i++) {int op = scanner.nextInt();int x = scanner.nextInt();int y = scanner.nextInt();if(op == 1) {//join函数int px = find(x);int py = find(y);if(px != py) {parent[px] = py;d[px] = rank[py];rank[py] += rank[px];}}else {int px = find(x);int py = find(y);if(px != py) {System.out.println("-1");}else {                System.out.println(Math.max(0, Math.abs(d[x]-d[y])-1));}}}}private static int find(int x) {if (parent[x]!=x) {int root=find(parent[x]);d[x]+=d[parent[x]];parent[x]=root;}return parent[x];}}

相关内容

热门资讯

【MySQL】锁 锁 文章目录锁全局锁表级锁表锁元数据锁(MDL)意向锁AUTO-INC锁...
【内网安全】 隧道搭建穿透上线... 文章目录内网穿透-Ngrok-入门-上线1、服务端配置:2、客户端连接服务端ÿ...
GCN的几种模型复现笔记 引言 本篇笔记紧接上文,主要是上一篇看写了快2w字,再去接入代码感觉有点...
数据分页展示逻辑 import java.util.Arrays;import java.util.List;impo...
Redis为什么选择单线程?R... 目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程?三、R...
【已解决】ERROR: Cou... 正确指令: pip install pyyaml
关于测试,我发现了哪些新大陆 关于测试 平常也只是听说过一些关于测试的术语,但并没有使用过测试工具。偶然看到编程老师...
Lock 接口解读 前置知识点Synchronized synchronized 是 Java 中的关键字,...
Win7 专业版安装中文包、汉... 参考资料:http://www.metsky.com/archives/350.htm...
3 ROS1通讯编程提高(1) 3 ROS1通讯编程提高3.1 使用VS Code编译ROS13.1.1 VS Code的安装和配置...
大模型未来趋势 大模型是人工智能领域的重要发展趋势之一,未来有着广阔的应用前景和发展空间。以下是大模型未来的趋势和展...
python实战应用讲解-【n... 目录 如何在Python中计算残余的平方和 方法1:使用其Base公式 方法2:使用statsmod...
学习u-boot 需要了解的m... 一、常用函数 1. origin 函数 origin 函数的返回值就是变量来源。使用格式如下...
常用python爬虫库介绍与简... 通用 urllib -网络库(stdlib)。 requests -网络库。 grab – 网络库&...
药品批准文号查询|药融云-中国... 药品批文是国家食品药品监督管理局(NMPA)对药品的审评和批准的证明文件...
【2023-03-22】SRS... 【2023-03-22】SRS推流搭配FFmpeg实现目标检测 说明: 外侧测试使用SRS播放器测...
有限元三角形单元的等效节点力 文章目录前言一、重新复习一下有限元三角形单元的理论1、三角形单元的形函数(Nÿ...
初级算法-哈希表 主要记录算法和数据结构学习笔记,新的一年更上一层楼! 初级算法-哈希表...
进程间通信【Linux】 1. 进程间通信 1.1 什么是进程间通信 在 Linux 系统中,进程间通信...
【Docker】P3 Dock... Docker数据卷、宿主机与挂载数据卷的概念及作用挂载宿主机配置数据卷挂载操作示例一个容器挂载多个目...