NOI2002 洛谷 P1196 银河英雄传说
神奇的并查集问题
题目描述
公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦
创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展。
宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争。泰山压
顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨
威利组织麾下三万艘战舰迎敌。
杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气。在
这次决战中,他将巴米利恩星域战场划分成30000列,每列依次编号为1, 2, …,
30000。之后,他把自己的战舰也依次编号为1, 2, …, 30000,让第i号战舰处于
第i列(i = 1, 2, …, 30000),形成“一字长蛇阵”,诱敌深入。这是初始阵形。当
进犯之敌到达时,杨威利会多次发布合并指令,将大部分战舰集中在某几列上,
实施密集攻击。合并指令为M i j,含义为让第i号战舰所在的整个战舰队列,作
为一个整体(头在前尾在后)接至第j号战舰所在的战舰队列的尾部。显然战舰
队列是由处于同一列的一个或多个战舰组成的。合并指令的执行结果会使队列增
大。 然而,老谋深算的莱因哈特早已在战略上取得了主动。在交战中,他可以通
过庞大的情报网络随时监听杨威利的舰队调动指令。
在杨威利发布指令调动舰队的同时,莱因哈特为了及时了解当前杨威利的战
舰分布情况,也会发出一些询问指令:C i j。该指令意思是,询问电脑,杨威利
的第i号战舰与第j号战舰当前是否在同一列中,如果在同一列中,那么它们之
间布置有多少战舰。
作为一个资深的高级程序设计员,你被要求编写程序分析杨威利的指令,以
及回答莱因哈特的询问。
最终的决战已经展开,银河的历史又翻过了一页……
输入输出格式
输入格式:
输入文件galaxy.in的第一行有一个整数T(1<=T<=500,000),表示总共有T
条指令。
以下有T行,每行有一条指令。指令有两种格式:
- M i j :i和j是两个整数(1<=i , j<=30000),表示指令涉及的战舰编号。
该指令是莱因哈特窃听到的杨威利发布的舰队调动指令,并且保证第i号战
舰与第j号战舰不在同一列。
- C i j :i和j是两个整数(1<=i , j<=30000),表示指令涉及的战舰编号。
该指令是莱因哈特发布的询问指令。
输出格式:
输出文件为galaxy.out。你的程序应当依次对输入的每一条指令进行分析和
处理:
如果是杨威利发布的舰队调动指令,则表示舰队排列发生了变化,你的程序
要注意到这一点,但是不要输出任何信息;
如果是莱因哈特发布的询问指令,你的程序要输出一行,仅包含一个整数,
表示在同一列上,第i 号战舰与第j 号战舰之间布置的战舰数目。如果第i 号战
舰与第j号战舰当前不在同一列上,则输出-1。
输入输出样例
4
M 2 3
C 1 2
M 2 4
C 4 2
-1
1
说明
【样例说明】
战舰位置图:表格中阿拉伯数字表示战舰编号
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<stack>
#include<cstring>
using namespace std;
struct nd{
int fa;
int pos;
int len;
}qu[];
int T;
char ch;
int father(int x){
if(qu[x].fa!=x){
int k=qu[x].fa;//先保存父节点,以便状态压缩后再处理
qu[x].fa=father(qu[x].fa);//并查集压缩状态,直接指向根节点
qu[x].pos+=qu[k].pos-; //合并队列,记录x位置 //不保存k,先写这条再写上面压缩状态会出错,不能理解 }
return qu[x].fa;
}
void move(int a,int b){
int fa=father(a),fb=father(b);
qu[fa].fa=fb;
qu[fa].pos=qu[fb].len+;//战舰接在原有队列后面
qu[fb].len+=qu[fa].len;//先处理pos再处理新队列长度
return;
}
void ask(int a,int b){
int fa=father(a),fb=father(b);
if(fa!=fb){
printf("-1\n");
return;
}
printf("%d\n",abs(qu[a].pos-qu[b].pos)-);//-1很重要
return;
}
int main(){
int i,j;
for(i=;i<=;i++){//初始化
qu[i].fa=i;
qu[i].pos=;
qu[i].len=;
}
scanf("%d\n",&T);
while(T--){
// scanf("%c %d %d\n",&ch,&i,&j);
cin>>ch>>i>>j;
if(ch=='M'){
move(i,j);
}
if(ch=='C'){
ask(i,j);
}
}
return ;
}
NOI2002 洛谷 P1196 银河英雄传说的更多相关文章
- 洛谷—— P1196 银河英雄传说
https://www.luogu.org/problem/show?pid=1196 题目描述 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始 ...
- 洛谷 [p1196] 银河英雄传说
所谓带权并查集 本题所求的不止是两个编号之间是否有关系,还要求两个编号之间有什么关系,这就要求我们维护多个数组,fa[]数组维护两个编号之间的连通性,dis[]维护编号为i的战舰到fa[i]之间的距离 ...
- 洛谷P1196 银河英雄传说
大意:你有30000个队列,第i个队列中只有i 有T个操作,1,把某个队列头接到另一个队列尾. 2,问两个元素之间的距离. 本题主要有三种解法. ①带权并查集. 具体来说就是,并查集维护当前集合的大小 ...
- [洛谷P4847]银河英雄传说V2
题目大意:有$n(n\leqslant2\times10^5)$个序列,有$m(m\leqslant2\times10^5)$个操作,分三种: 1. $M\;x\;y:$把$x$所在的序列放在$y$所 ...
- Luogu P1196 银河英雄传说
Luogu P1196 银河英雄传说 我们考虑用并查集来维护战舰的情况. 同时,我们用一个$d$数组来记录$x$与$fa[x]$之间的距离.再用$size$数组记录战舰当前所在列的战舰数. 易知两艘在 ...
- 边带权并查集 学习笔记 & 洛谷P1196 [NOI2002] 银河英雄传说 题解
花了2h总算把边带权并查集整明白了qaq 1.边带权并查集的用途 众所周知,并查集擅长维护与可传递关系有关的信息.然而我们有时会发现并查集所维护的信息不够用,这时"边带权并查集"就 ...
- 加权并查集(银河英雄传说,Cube Stacking)
洛谷P1196 银河英雄传说 题目描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展.宇宙历七九九年,银河系的两大军事集团在 ...
- NOI2002_ Galaxy银河英雄传说86
NOI2002_ Galaxy银河英雄传说86 公元五八○一年,地球居民迁移至金牛座α第二行星,:宇宙历七九九年,银河系的两大军事集团在巴米利恩星:杨威利擅长排兵布阵,巧妙运用各种战术屡次以少 ...
- P4847 银河英雄传说V2 题解(Splay)
题目链接 P4847 银河英雄传说V2 解题思路 我天哪!!!\(splay\)在\(rotate\)的时候先\(upd(y)\)再\(upd(x)\)!!以后不能再因为这个\(WA\)一晚上了!!! ...
随机推荐
- MySchool
USE [MySchool] GO /****** Object: Table [dbo].[Grade] Script Date: 08/06/2014 15:03:17 ******/ SET A ...
- Mac上安装node.js
1.下载node for mac并一路默认安装 2.测试成功否 3.copy this file to test(save as javascript file) var http = require ...
- CSS规则的执行顺序(转)
你对CSS规则的执行顺序是否了解,这里和大家分享一下,若两条规则具有相同的权值.起源及特殊性,那在样式表中最后出现的规则优先. 1.CSS规则之特殊性 首先来看一下这个例子将会发生的情形: <s ...
- 在PLSQL中不能使用中文作为查询条件查询数据
解决方法: 1.在oracle服务端的注册表中找到oracle-->key_oradb11g_home1,在右侧找到NLS_LANG,将其数值数据改为SIMPLIFIED CHINESE_CH ...
- android ContentResolver详解
查询出来的cursor的初始位置是指向第一条记录的前一个位置的cursor.moveToFirst()指向查询结果的第一个位置.一般通过判断cursor.moveToFirst()的值为true或fa ...
- 本地环境,Ecshop安装教程
最近有个项目需要用ECshop来做,之前没接触过ECshop,今天去网上找了下安装教程,现在发出来分享一下. 1. ecshop网店系统最新版本是ECSHOP V2.7.3,去官网下载utf8和gbk ...
- SQL SERVER提供了大量的WINDOWS和SQLSERVER专用的排序规则
初始选择结果 select * from WordDictionary 下面是按照汉字拼音排序 select * from WordDictionary order by word collate C ...
- JS 模板引擎之JST模板
项目中有用到JST模板引擎,于是抽个时间出来,整理了下关于JST模板引擎的相关内容. 试想一个场景,当点击页面上列表的翻页按钮后,通过异步请求获得下一页的列表数据并在页面上显示出来.传统的JS做法是编 ...
- SimpleDateFormat非线程安全
文章列表 1)SimpleDateFormat的线程安全问题与解决方案 2)深入理解Java:SimpleDateFormat安全的时间格式化
- [CareerCup] 9.3 Magic Index 魔法序号
9.3 A magic index in an array A[0.. .n-1] is defined to be an index such that A[i] = i. Given a sort ...