题意:一个企业要去收购一些公司把,使的每个企业之间互联,刚开始每个公司互相独立

   给出n个公司,两种操作

   E I:询问I到I它连接点最后一个公司的距离

   I I J:将I公司指向J公司,也就是J公司是I公司的上级,距离为abs(I-J)%1000(貌似G++不支持abs,PE了两发)

思路:转化一下题意就行了,首先刚开始的时候每个公司都是独立的,I操作就是并查集中合并操作,将I这课树并到J这个树上,

   E操作要求的东西就是 I到I的根节点的距离,先看一个没有路径压缩直接暴力的方法把、(本以为不会过的,因为数据很大)

    时间是:2222ms  被系统藐视了

  等等,现已题目中所给的例子来把 直接执行完I 操作 ,最后得到的是  3->1->2->4

 那么E 3所得到的结果是 (3-1)%1000+(2-1)%1000+(4-2)%1000=5

  并查集本身就是这样的结果,所以直接从子节点向根节点找过去,一边找一遍求距离

  

#include<cstdio>
#include<cstring>
#include<cmath>
const int qq=20000+5;
int pre[qq],sum[qq];
int ans;
void init(int n)
{
for(int i = 0; i <= n; ++i){
pre[i]=i;
sum[i]=0;
}
}
int find(int x)
{
if(x==pre[x]) return x;
else{
int dis=x-pre[x]>0?x-pre[x]:pre[x]-x;
dis%=1000;
ans+=dis;
return find(pre[x]);
}
}
int main()
{
int t,n;scanf("%d",&t);
while(t--){
scanf("%d",&n);
init(n);
char s[10];
while(scanf("%s",s) && (s[0]!='O')){
if(s[0] == 'E'){
int a;
scanf("%d",&a);
ans = 0;
find(a);
printf("%d\n",ans);
}
else if(s[0] == 'I'){
int a,b;
scanf("%d%d",&a,&b);
pre[a] = b;
}
}
}
return 0;
}

路径压缩版、 66MS

#include<cstdio>
#include<cstring>
#include<cmath>
const int qq=20000+5;
int pre[qq],dis[qq];
int ans;
void init(int n)
{
for(int i = 0; i <= n; ++i){ //初始化、
pre[i]=i;
dis[i]=0;
}
}
int find(int x) //只想说递归的调用真的很神奇,然而我还是个半桶水
{
if(x==pre[x]) return x;
int flag=find(pre[x]); // 在find函数中直接进行路径压缩
dis[x]=dis[x]+dis[pre[x]]; // 一边压缩一遍更新子节点到根节点的距离值
return pre[x]=flag; //这里是压缩路径、
}
int main()
{
int t,n;scanf("%d",&t);
while(t--){
scanf("%d",&n);
init(n);
char s[10];
while(scanf("%s",s) && (s[0]!='O')){
if(s[0] == 'E'){
int a;
scanf("%d",&a);
find(a); //对于要找的那个a,在此之前去压缩路径并更新到根节点的距离值
printf("%d\n",dis[a]);
}
else if(s[0] == 'I'){
int a,b;
scanf("%d%d",&a,&b);
pre[a]=b; // 合并
int ans=a-b>0?a-b:b-a;
ans%=1000; //求距离、
dis[a]=ans; //然后赋值
}
}
}
return 0;
}

UVA 3027 Corporative Network 带权并查集、的更多相关文章

  1. UVALive 3027 Corporative Network 带权并查集

                         Corporative Network A very big corporation is developing its corporative networ ...

  2. POJ1962Corporative Network[带权并查集]

    Corporative Network Time Limit: 3000MS   Memory Limit: 30000K Total Submissions: 3945   Accepted: 14 ...

  3. POJ1962:Corporative Network【带权并查集】

    <题目链接> 题目大意: n个节点,若干次询问,I x y表示从x连一条边到y,权值为|x-y|%1000:E x表示询问x到x所指向的终点的距离.   解题分析: 与普通的带权并查集类似 ...

  4. 【poj 1962】Corporative Network(图论--带权并查集 模版题)

    P.S.我不想看英文原题的,但是看网上题解的题意看得我 炒鸡辛苦&一脸懵 +_+,打这模版题的代码也纠结至极了......不得已只能自己翻译了QwQ . 题意:有一个公司有N个企业,分成几个网 ...

  5. UVA 12232 - Exclusive-OR(带权并查集)

    UVA 12232 - Exclusive-OR 题目链接 题意:有n个数字.一開始值都不知道,每次给定一个操作,I a v表示确认a值为v,I a b v,表示确认a^b = v,Q k a1 a2 ...

  6. UVA - 10004 Bicoloring(判断二分图——交叉染色法 / 带权并查集)

    d.给定一个图,判断是不是二分图. s.可以交叉染色,就是二分图:否则,不是. 另外,此题中的图是强连通图,即任意两点可达,从而dfs方法从一个点出发就能遍历整个图了. 如果不能保证从一个点出发可以遍 ...

  7. 【bzoj 1202】[HNOI2005] 狡猾的商人(图论--带权并查集+前缀和)

    题意:一个账本记录了N个月以来的收入情况,现在有一个侦探员不同时间偷看到M段时间内的总收入,问这个账本是否为假账. 解法:带权并查集+前缀和.   判断账本真假是通过之前可算到的答案与当前读入的值是否 ...

  8. 【poj 1988】Cube Stacking(图论--带权并查集)

    题意:有N个方块,M个操作{"C x":查询方块x上的方块数:"M x y":移动方块x所在的整个方块堆到方块y所在的整个方块堆之上}.输出相应的答案. 解法: ...

  9. 并查集——poj2236(带权并查集)

    题目:Wireless Network 题意:给定n台已损坏计算机的位置和计算机最远通信距离d,然后分别根据命令执行以下两种操作: "O p" (1 <= p <= N ...

随机推荐

  1. oracle-DML-2

    1.update 语句 update  table set  [column,column......] where  column ='' 示例: update   customers set   ...

  2. laravel-- 在laravel操作redis数据库的数据类型(string、哈希、无序集合、list链表、有序集合)

    安装redis和连接redis数据库 在controller头部引入 一.基本使用 public function RedisdDbOne() { // 清空Redis数据库 Redis::flush ...

  3. selenium 常见问题之 nknown error: call function result missing ‘value’

    运行时候出现错误提示如下: 出现该问题原因:chrome浏览器自动升级.导致和chromedriver支持的版本不匹配. 解决方案有两种(本人采用的是第一种方式解决办法.): 1.下载和当前使用的ch ...

  4. LintCode_372 在O(1)时间复杂度删除链表节点

    题目 给定一个单链表中的表头和一个等待被删除的节点(非表头或表尾).请在在O(1)时间复杂度删除该链表节点.并在删除该节点后,返回表头. 思路 因为O(1)内删除所以 不能从头节点去遍历找他的前驱节点 ...

  5. 学习String类

    1. 描述: String类是java中比较常用的类, 表示字符串类型 当拼接大量数据时, String类性能没有StringBuilder和StringBuffer性能高 2. 常用的String语 ...

  6. PHP闭包实现函数的自调用实现递归

    根据pathinfo访问对应得controller,如ip:port/home/index/index则会访问home目录下的IndexController的index方法:如果不指定pathinfo ...

  7. BOT建设经营转让,PPP公私合作

    PPP.BOT两种模式有什么区别? BOT模式(build-operate-transfer),由投资方建设并专营一定期限最后移交政府的方式:PPP模式(public-private-partners ...

  8. 【JZOJ4761】【NOIP2016提高A组模拟9.7】鼎纹

    题目描述 输入 输出 样例输入 2 3 4 4 2 1100 0110 1100 10 01 10 00 2 2 2 2 11 11 01 10 样例输出 YES NO 数据范围 解法 由于鼎纹中的第 ...

  9. 【JZOJ4792】【NOIP2016提高A组模拟9.21】整除

    题目描述 麦克雷有一个1~n的排列,他想知道对于一些区间,有多少对区间内的数(x,y),满足x能被y整除. 输入 第一行包含2个正整数n,m.表示有n个数,m个询问. 接下来一行包含n个正整数,表示麦 ...

  10. 学习iOS设计--iOS8的颜色、文字和布局学习

    在去年,Apple针对新时代用户彻底更新了其设计语言.现在的设计语言相对之前大为简化,能够让设计师将精力集中到动画和功能上,而不是繁复的视觉细节上. 很多人都曾问过我:设计应当如何入门?成为一名优秀设 ...