NOI2002银河英雄传说

原先就看过这道题,觉得很复杂。

不知道为什么今天一看觉得好水啊……

难道这就是并查集的启发式合并?

数组d【i】表示i到其父节点的距离,即中间隔了多少船舰。

数组sum【i】记录以i为根的集合总共有多少个元素,将新节点插入的时候距离设为sum【i】就好了。

代码:

 1 var  fa,d,sum:array[0..30001] of longint;
2 t,i,xx,yy,x,y:longint;
3 ch:string[1];
4 function find(x:longint):longint;
5 var tmp:longint;
6 begin
7 tmp:=fa[x];
8 if fa[x]<>x then fa[x]:=find(fa[x]);
9 d[x]:=d[x]+d[tmp];
10 exit(fa[x]);
11 end;
12 procedure main;
13 begin
14 readln(t);
15 for i:=1 to 30001 do begin fa[i]:=i;d[i]:=0;sum[i]:=1;end;
16 for i:=1 to t do
17 begin
18 readln(ch,x,y);
19 xx:=find(x);yy:=find(y);
20 if ch=‘C‘then
21 begin
22 if xx<>yy then writeln(‘-1‘) else writeln(abs(d[y]-d[x])-1);
23 end
24 else
25 begin
26 fa[xx]:=yy;d[xx]:=sum[yy];inc(sum[yy],sum[xx]);sum[xx]:=0;
27 end;
28 end;
29 end;
30 begin
31 main;
32 end.

1A……

NOI2002银河英雄传说,布布扣,bubuko.com

时间: 2024-12-16 12:58:08

NOI2002银河英雄传说的相关文章

数据结构(并查集):260. [NOI2002] 银河英雄传说

260. [NOI2002] 银河英雄传说 ★★☆   输入文件:galaxy.in   输出文件:galaxy.out   简单对比时间限制:5 s   内存限制:128 MB [问题描述] 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌. 杨威利擅长排兵布

[noi2002]银河英雄传说

Description 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展.        宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌.        杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气.在这次决战中,他将巴米利恩星域战场划分成30000列,每列依次编号为1, 2, …, 3000

做题记录:P1196 [NOI2002]银河英雄传说

P1196 [NOI2002]银河英雄传说 //P1196 [NOI2002]银河英雄传说 #include<iostream> #include<cstdio> #include<cmath> using namespace std; int f[30005],p[30005],s[30005]; //f[i]表示第i艘战舰与哪一艘战舰在同一列中 //p[i]表示第i艘战舰的前面有多少艘战舰 //s[i]表示第i列有多少艘战舰 void find_x(int x)//

P1196 [NOI2002]银河英雄传说

题目描述 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌. 杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气.在这次决战中,他将巴米利恩星域战场划分成30000列,每列依次编号为1, 2, …,30000.之后,他把自己的战舰也依次编号为1, 2,

洛谷 P1196 [NOI2002]银河英雄传说

有很多人都把这道题讲得很详细了,我就不再重复了. 要总结的是,这可以看作一种"边带权"的并查集,对于这种并查集我们可以另开数组记录边上的关系,然后在find和unite的同时对关系进行维护. 于是此题中我们用一个 d 数组来记录当前战舰 到 这列战舰最前面的战舰 的战舰数量, 用一个 size 数组(在程序中为了避免关键字换成了siz)记录当前战舰后面跟了多少战舰(为了方便M操作时更新d). 具体的维护方式参考代码. 1 #include <bits/stdc++.h> 2

【NOI2002】银河英雄传说

Description 公元五八○一年,地球居民迁移至金牛座 α 第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌. 杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气.在这次决战中,他将巴米利恩星域战场划分成 30000 列,每列依次编号为 1, 2, …,30000.之后,他把自己的

VijosP1443:银河英雄传说

描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌. 杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气.在这次决战中,他将巴米利恩星域战场划分成30000列,每列依次编号为1, 2, …, 30000.之后,他把自己的战舰也依次编号为1, 2,

codevs1540 银河英雄传说

描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌. 杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气.在这次决战中,他将巴米利恩星域战场划分成30000列,每列依次编号为1, 2, …, 30000.之后,他把自己的战舰也依次编号为1, 2,

银河英雄传说

题目描述 公元五八○一年,地球居民迁至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山压顶集团派宇宙舰队司令莱因哈特率领十万余艘战舰出征,气吞山河集团点名将杨威利组织麾下三万艘战舰迎敌. 杨威利擅长排兵布阵,巧妙运用各种战术屡次以少胜多,难免恣生骄气.在这次决战中,他将巴米利恩星域战场划分成30000列,每列依次编号为1, 2, -,30000.之后,他把自己的战舰也依次编号为1, 2,