洛谷P1196 [NOI2002]银河英雄传说(带权并查集)
题目描述
公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展。
宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争。泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌。
杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气。在这次决战中,他将巴米利恩星域战场划分成 3000030000 列,每列依次编号为 1, 2, …,300001,2,…,30000 。之后,他把自己的战舰也依次编号为 1, 2, …, 300001,2,…,30000 ,让第 ii 号战舰处于第 ii 列 (i = 1, 2, …, 30000)(i=1,2,…,30000) ,形成“一字长蛇阵”,诱敌深入。这是初始阵形。当进犯之敌到达时,杨威利会多次发布合并指令,将大部分战舰集中在某几列上,实施密集攻击。合并指令为 M_{i,j}Mi,j ,含义为第i号战舰所在的整个战舰队列,作为一个整体(头在前尾在后)接至第j号战舰所在的战舰队列的尾部。显然战舰队列是由处于同一列的一个或多个战舰组成的。合并指令的执行结果会使队列增大。
然而,老谋深算的莱因哈特早已在战略上取得了主动。在交战中,他可以通过庞大的情报网络随时监听杨威利的舰队调动指令。
在杨威利发布指令调动舰队的同时,莱因哈特为了及时了解当前杨威利的战舰分布情况,也会发出一些询问指令: C_{i,j}Ci,j 。该指令意思是,询问电脑,杨威利的第 ii 号战舰与第 jj 号战舰当前是否在同一列中,如果在同一列中,那么它们之间布置有多少战舰。
作为一个资深的高级程序设计员,你被要求编写程序分析杨威利的指令,以及回答莱因哈特的询问。
最终的决战已经展开,银河的历史又翻过了一页……
输入输出格式
输入格式:
第一行有一个整数 T(1 \le T \le 500,000)T(1≤T≤500,000) ,表示总共有 TT 条指令。
以下有 TT 行,每行有一条指令。指令有两种格式:
M_{i,j}Mi,j : ii 和 jj 是两个整数 (1 \le i,j \le 30000)(1≤i,j≤30000) ,表示指令涉及的战舰编号。该指令是莱因哈特窃听到的杨威利发布的舰队调动指令,并且保证第 ii 号战舰与第 jj 号战舰不在同一列。
C_{i,j}Ci,j : ii 和 jj 是两个整数 (1 \le i,j \le 30000)(1≤i,j≤30000) ,表示指令涉及的战舰编号。该指令是莱因哈特发布的询问指令。
输出格式:
依次对输入的每一条指令进行分析和处理:
如果是杨威利发布的舰队调动指令,则表示舰队排列发生了变化,你的程序要注意到这一点,但是不要输出任何信息;
如果是莱因哈特发布的询问指令,你的程序要输出一行,仅包含一个整数,表示在同一列上,第 ii 号战舰与第 jj 号战舰之间布置的战舰数目。如果第 ii 号战舰与第 jj 号战舰当前不在同一列上,则输出 -1−1 。
输入输出样例
说明
【样例说明】
战舰位置图:表格中阿拉伯数字表示战舰编号

这题真是妙啊。
一开始也想到了并查集,但是感觉不能路径压缩,然后就在想别的做法
其实带权并查集是可以路径压缩的!!
只要记录一下距离根节点的深度就行!
更新的时候把深度一块更新了。
话说能不能用lct做?
#include<cstdio>
#include<vector>
#include<algorithm>
#include<cstring>
#include<map>
#define LL long long
using namespace std;
const int MAXN = 1e6 + ;
inline int read() {
char c = getchar(); int x = , f = ;
while(c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while(c >= '' && c <= '') x = x * + c - '', c = getchar();
return x * f;
}
int N, fa[MAXN], dis[MAXN], siz[MAXN];
int find(int x) {
if(fa[x] != x) {
int pre = fa[x];
fa[x] = find(fa[x]);
dis[x] += dis[pre];
}
return fa[x];
}
void merge(int x, int y) {
int fx = find(x), fy = find(y);
fa[fx] = fy;
dis[fx] += siz[fy];
siz[fy] += siz[fx];
}
main() {
#ifdef WIN32
freopen("a.in", "r", stdin);
#endif
N = read();
for(int i = ; i <= ; i++) fa[i] = i, siz[i] = ;
while(N--) {
char c = '.';
while(c != 'C' && c != 'M') c = getchar();
int x = read(), y = read();
if(c == 'M') merge(x, y);
else {
if(find(x) != find(y)) puts("-1");
else printf("%d\n", abs(dis[x] - dis[y]) - );
}
}
return ;
}
洛谷P1196 [NOI2002]银河英雄传说(带权并查集)的更多相关文章
- P1196 [NOI2002]银河英雄传说(带权并查集)
		
这个题的题目背景很是宏大,什么宇宙战舰的都出来了.但细细一看,我们就会发现,这是带权并查集的题目,首先我们还是像之前在并查集中的操作一样,但在这里我们还是应该开数组来维护所要加的权值,两个战舰是否在同 ...
 - NOI2002银河英雄传说-带权并查集
		
[NOI2002]银河英雄传说-带权并查集 luogu P1196 题目描述 Description: 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年, ...
 - [NOI2002] 银河英雄传说 (带权并查集)
		
题目描述 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶 ...
 - [洛谷P1196][NOI2002]银河英雄传说 - 带偏移量的并查集(1)
		
Description 公元五八〇一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发 ...
 - NOI2002银河英雄传说——带权并查集
		
题目:https://www.luogu.org/problemnew/show/P1196 关键点在于存下每个点的位置. 自己糊涂的地方:位置是相对于谁的位置? 因为每次给一个原来是fa的点赋位置时 ...
 - 边带权并查集 学习笔记 & 洛谷P1196 [NOI2002] 银河英雄传说 题解
		
花了2h总算把边带权并查集整明白了qaq 1.边带权并查集的用途 众所周知,并查集擅长维护与可传递关系有关的信息.然而我们有时会发现并查集所维护的信息不够用,这时"边带权并查集"就 ...
 - luogu 1196 银河英雄传说 带权并查集
		
带权并查集,其实有点像许多队列问情况的小学奥数 #include<bits/stdc++.h> #define rep(i,x,y) for(register int i=x;i<= ...
 - 【luoguP1196】 [NOI2002]银河英雄传说--边带权并查集 ,
		
题目描述 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶 ...
 - 洛谷P1196[NOI2002]银河英雄传说-并查集扩展
		
银河英雄传说 题意:在并查集的基础上,还要求出同一集合的两个点的距离 这道题用并查集自己是知道的,但是竟然可以这么骚的操作. 下面转自大佬的查详细题解 初见这道题,首先想到的方法当然是直接模拟,模拟每 ...
 
随机推荐
- java生产者,消费者
			
有很多实现的方法 使用blockingqueue实现 demo import java.util.concurrent.LinkedBlockingQueue; /** * Created by 58 ...
 - Linux 启动SVN服务
			
#使用默认端口3690启动svn服务svnserve -d -r /home/svndata # 如果出现#svnserve: Can't bind server socket: Address al ...
 - Spring课程 Spring入门篇 4-9 Spring bean装配之对jsr支持的说明
			
1 解析 1.1 疑问:2.2去掉@resource注解,为什么不能赋值?不是有set方法了吗? 1.2 @resource注解版本支持 1.3 没有显式指定@resource的那么,默认名称从何获得 ...
 - SpannableString与SpannableStringBuilder使用
			
转自:http://blog.it985.com/14433.html1.SpannableString.SpannableStringBuilder与String的关系 首先SpannableStr ...
 - 简谈 Java 中的泛型通配符
			
很好的一篇文章https://zhuanlan.zhihu.com/p/26681625
 - winform DataGridView 通用初始化
			
void DGV_Init() { //名称 类型 设备数 累计转发次数 累计转发数据数 状态 ; i < ; i++) { DataGridViewTextBoxColumn dc = new ...
 - 【Leetcode】【Easy】Plus One
			
Given a non-negative number represented as an array of digits, plus one to the number. The digits ar ...
 - sql developer中英文切换
			
今天使用oracle sql developer时做调优建议时找到的建议显示为?的乱码,本人sql developer为中文版,修改为英文版后问题解决. 查看帮助菜单中的属性选项卡,user.lang ...
 - python操作oracle小测试
			
首先使用python操作数据库需要导入cx_Oracle包import cx_Oracle这个包需要单独下载,下载地址:https://pypi.python.org/pypi/cx_Oracle使用 ...
 - MyEclipse2015Stable3.0破解方法
			
原理大概是这样的(个人粗略分析):获取当前的日期,来设置证书失效日期,解析后生成码-->再转码,最后生成序列号. 1.新建一个Java工程,(不会安装jdk创建环境变量的,请前往传送门:链接.) ...