A1. 道路修建 Small(BNUOJ)
A1. 道路修建 Small
64-bit integer IO format: %lld Java class name: Main
无向图
初始有
个点,从
到
依次标号,但是没有边,
接下来有
次操作,从
到
依次标号,你需要对每种操作输出相应的结果,操作分为两种:
|
输入格式 |
操作说明 |
输出结果 |
|
0_u_v |
加入一条连接标号为 |
输出加边后图 |
|
1_u_v |
查询标号为 |
如果连通,输出 |
(输入格式中的下划线‘_’表示实际输入文件中的空格)
Input
第一行是一个正整数
,表示测试数据的组数,
对于每组测试数据,
第一行包含两个整数
、
,
接下来
行,每行是
个整数
、
、
,请注意所给的
、
均是经过加密的,
解密方式是
、
,其中
表示上一次操作的输出结果,
初始
,保证
,解密后
且
。
Output
对于每组测试数据,
输出
行,每行包含一个整数,表示操作的输出结果。
Sample Input
1 4 7 0 1 2 1 1 0 0 1 3 0 0 1 1 0 1 0 1 7 1 0 5
Sample Output
3 0 2 2 3 1 6
思路:并查级。
用并查集判断有几个联通块。然后每次加点的时候将不同的两个集合合并到一起时,每个集合里的点相连通的时间最早时间就是此时合并的时间,开个yy数组记录就行了。
1 #include<stdio.h> 2 #include<algorithm> 3 #include<string.h> 4 #include<stdlib.h> 5 #include<math.h> 6 #include<iostream> 7 #include<vector> 8 #include<cstdio> 9 #define sc(x) scanf("%I64d",&x) 10 #define pr(x) printf("%I64d",x) 11 #define prr(x) printf(" %I64d",x) 12 #define prrr(x) printf("%I64d\n",x) 13 typedef long long ll; 14 const ll N=1e9+7; 15 using namespace std ; 16 vector<int>aa[1005];//记录集合中的点 17 int bb[10005]; 18 int dd[10005]; 19 int cc[10005];//并差集权重数组 20 int gg[10005]; 21 int yy[1005][1005];//记录最早联通的时间 22 int main(void) 23 { 24 int i,j,k,p,q,n,m,s; 25 scanf("%d",&k); 26 while(k--) 27 { 28 for(i=0; i<1005; i++) 29 { 30 aa[i].clear(); 31 aa[i].push_back(i);//先将自己加入集合 32 bb[i]=i; 33 cc[i]=1; 34 } 35 scanf("%d %d",&n,&m); 36 memset(yy,0,sizeof(yy)); 37 int nn=0;//初始化输出 38 int ans=0; 39 for(i=1; i<=m; i++) 40 { 41 scanf("%d %d %d",&s,&p,&q); 42 p=p^nn; 43 q=q^nn; 44 if(s==0) 45 { 46 int x,y; 47 for(x=p; bb[x]!=x;) 48 { 49 x=bb[x]; 50 } 51 for(y=q; bb[y]!=y;) 52 { 53 y=bb[y]; 54 } 55 if(x!=y) 56 { 57 yy[p][q]=i; 58 yy[q][p]=i; 59 60 for(j=0; j<aa[x].size(); j++) 61 { 62 for(int r=0; r<aa[y].size(); r++) 63 { 64 yy[aa[x][j]][aa[y][r]]=yy[aa[y][r]][aa[x][j]]=i; 65 66 } 67 }//记录联通最早的时间,因为他们在此时刚和并 68 yy[x][y]=i; 69 yy[y][x]=i; 70 if(cc[x]>cc[y])//合并集合 71 { 72 cc[x]+=cc[y]; 73 bb[y]=x; 74 for(j=0; j<aa[y].size(); j++) 75 { 76 aa[x].push_back(aa[y][j]); 77 } 78 aa[x].push_back(y); 79 aa[y].clear(); 80 81 } 82 else 83 { 84 cc[y]+=cc[x]; 85 bb[x]=y; 86 for(j=0; j<aa[x].size(); j++) 87 { 88 aa[y].push_back(aa[x][j]); 89 } 90 aa[y].push_back(x); 91 aa[x].clear(); 92 93 } 94 } 95 int gh; 96 for(int w=1; w<=n; w++) 97 { 98 for( gh=w; bb[gh]!=gh;) 99 {100 gh=bb[gh];101 }102 gg[w]=gh;103 }104 sort(gg+1,gg+1+n);//判断联通段105 int cnt=1;106 for(int h=2; h<=n; h++)107 {108 if(gg[h]!=gg[h-1])109 {110 cnt++;111 }112 }113 114 nn=cnt;115 printf("%d\n",cnt);116 }117 else if(s==1)118 {119 printf("%d\n",yy[p][q]);120 nn=yy[p][q];121 }122 }123 124 }125 return 0;126 }
A1. 道路修建 Small(BNUOJ)的更多相关文章
- quailty's Contest #1 A1 道路修建 Small
暴力.每次合并两个点之后,把新产生的连通关系都记录下来. #include<cstdio> #include<algorithm> #include<vector> ...
- 道路修建 2(自创题+题解)(From NOI2011)
道路修建这道题想来各位不陌生(传送门在此——Bzoj2435),看了此题,一开始以为是最初各个点处于分散状态,然后做了一下,直到发现标程都有点问题,才发现原题是说本来各点已经处于连接完毕的状态(phi ...
- 【BZOJ-2435】道路修建 (树形DP?)DFS
2435: [Noi2011]道路修建 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3115 Solved: 1002[Submit][Statu ...
- 【bzoj2435】[NOI2011]道路修建
题目描述 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建恰好 n – 1条双向道路. 每条道路的修 ...
- 【NOI2011】道路修建 BFS
[NOI2011]道路修建 Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建 ...
- 【BZOJ】2435: [Noi2011]道路修建(树形dp)
http://www.lydsy.com/JudgeOnline/problem.php?id=2435 我怎么感觉那么水.. 坑的是,dfs会爆...好吧..用bfs.. //upd:我的智商也是醉 ...
- bzoj 2435: [Noi2011]道路修建 树上 dp
2435: [Noi2011]道路修建 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...
- 2435: [Noi2011]道路修建 - BZOJ
Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建恰好 n – 1条双向道路. ...
- NOI2011道路修建
2435: [Noi2011]道路修建 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1974 Solved: 550[Submit][Status ...
随机推荐
- 微信小程序扫描普通二维码打开小程序的方法
很久没有写博客了,之前换了一份工作,很久没有做Android开发了,现在转做前端开发了,记录一下遇到的问题及解决的方法. 最近做微信小程序开发,遇到一个需求,后台管理系统生成的问卷和投票会有一个二维码 ...
- 基于《CSAPP第九章 虚拟内存》的思考和总结
在csapp的描述中,虚拟内存的形象更加具化,虚拟内存被组织为一个由存放在磁盘上的N个连续的字节大小的单元组成的数组,内存充当了磁盘的缓存,粗呢内存的许多概念与SRAM缓存是相似的.虚拟页面有以下三种 ...
- [C++] vptr, where are you?
Search(c++在线运行). 有的网站很慢--不是下面的程序有问题. #include <string.h> #include <stdio.h> #include < ...
- adhere, adjust, adjacent
adhere to stick,不是to here. 在古英语里,stick是twig(细树枝).fasten(想必是用twig来固定).后引申为粘住.stick还有stab, pierce的意思,想 ...
- ace
ace An ace is a playing card, die or domino with a single pip. In the standard French deck, an ace h ...
- 零基础学习java------day12------数组高级(选择排序,冒泡排序,二分查找),API(Arrays工具类,包装类,BigInteger等数据类型,Math包)
0.数组高级 (1)选择排序 它的工作原理是每一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的起始位置 ...
- JavaScript小数、百分数的转换
百分数转化为小数 function toPoint(percent){ var str=percent.replace("%",""); str= str/10 ...
- PS只能各个工具使用的注意知识点
1.图章工具 <仿制图章工具>使用方法:按住alt点击吸取干净的地方,然后松开alt键,按住鼠标左键拖动或左击 擦拭 图章区域放大缩小,是按住alt键+鼠标右键左右滑动 当图片中多个图 ...
- Xcode功能快捷键
隐藏xcode command+h退出xcode command+q关闭窗口 command+w关闭所有窗口 command+option+w关闭当前项目 command+control+w关闭当前文 ...
- 【Java 调优】Java性能优化
Java性能优化的50个细节(珍藏版) 1. 尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间,提高加载的效率,但并不是所有地方都适用于单例,简单来说,单例主要适用于以下三个方面: ...
,表示最早在第
。