A1. 道路修建 Small

Time Limit: 1000ms
Memory Limit: 131072KB

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)的更多相关文章

  1. quailty's Contest #1 A1 道路修建 Small

    暴力.每次合并两个点之后,把新产生的连通关系都记录下来. #include<cstdio> #include<algorithm> #include<vector> ...

  2. 道路修建 2(自创题+题解)(From NOI2011)

    道路修建这道题想来各位不陌生(传送门在此——Bzoj2435),看了此题,一开始以为是最初各个点处于分散状态,然后做了一下,直到发现标程都有点问题,才发现原题是说本来各点已经处于连接完毕的状态(phi ...

  3. 【BZOJ-2435】道路修建 (树形DP?)DFS

    2435: [Noi2011]道路修建 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 3115  Solved: 1002[Submit][Statu ...

  4. 【bzoj2435】[NOI2011]道路修建

    题目描述 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建恰好 n – 1条双向道路. 每条道路的修 ...

  5. 【NOI2011】道路修建 BFS

    [NOI2011]道路修建 Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建 ...

  6. 【BZOJ】2435: [Noi2011]道路修建(树形dp)

    http://www.lydsy.com/JudgeOnline/problem.php?id=2435 我怎么感觉那么水.. 坑的是,dfs会爆...好吧..用bfs.. //upd:我的智商也是醉 ...

  7. bzoj 2435: [Noi2011]道路修建 树上 dp

    2435: [Noi2011]道路修建 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  8. 2435: [Noi2011]道路修建 - BZOJ

    Description 在 W 星球上有 n 个国家.为了各自国家的经济发展,他们决定在各个国家之间建设双向道路使得国家之间连通.但是每个国家的国王都很吝啬,他们只愿意修建恰好 n – 1条双向道路. ...

  9. NOI2011道路修建

    2435: [Noi2011]道路修建 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1974  Solved: 550[Submit][Status ...

随机推荐

  1. leetcode刷题之数组NO.4

    1.题目 给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序. 示例: 输入: [0,1,0,3,12] 输出: [1,3,12,0,0] 说明: 必须在原数 ...

  2. Netty | 第1章 Java NIO 网络编程《Netty In Action》

    目录 前言 1. Java 网络编程 1.1 Javs NIO 基本介绍 1.2 缓冲区 Buffer 1.2 通道 Channel 1.3 选择器 Selector 1.4 NIO 非阻塞网络编程原 ...

  3. 日常Java测试第一段 2021/11/12

    课堂测试一 package word_show;import java.io.BufferedReader;import java.io.FileNotFoundException;import ja ...

  4. 图形学3D渲染管线学习

    图形学3D渲染管线 DX和OpenGL左右手坐标系不同,会有一些差距,得出的矩阵会不一样; OpenGL的投影平面不是视景体的近截面: 顶点(vertexs) 顶点坐标,颜色,法线,纹理坐标(UV), ...

  5. 【STM32】使用SDIO进行SD卡读写,包含文件管理FatFs(八)-认识内存管理

    [STM32]使用SDIO进行SD卡读写,包含文件管理FatFs(一)-初步认识SD卡 [STM32]使用SDIO进行SD卡读写,包含文件管理FatFs(二)-了解SD总线,命令的相关介绍 [STM3 ...

  6. Oracle—回车、换行符

    1.回车换行符 chr(10)是换行符, chr(13)是回车, 增加换行符: select ' update ' || table_name || ' set VALID_STATE =''0A'' ...

  7. Spring Boot发布war包流程

    1.修改web model的pom.xml <packaging>war</packaging> SpringBoot默认发布的都是jar,因此要修改默认的打包方式jar为wa ...

  8. 记一次单机Nginx调优,效果立竿见影

    一.物理环境 1.系统是Centos 8,系统配置 2核4G,8M带宽,一台很轻的应用服务器. 2.站点部署情况.但站点部署两个实例,占用两个端口,使用nginx 负载转发到这两个web站点.  二. ...

  9. show_slave_status参数详解

    #这个是指slave 连接到master的状态 #当前在等待主发送事件 Slave_IO_State: Waiting for master to send event #master地址 Maste ...

  10. 转:select、poll、epoll之间的区别总结[整理]

    转:select.poll.epoll之间的区别总结[整理] select,poll,epoll都是IO多路复用的机制.I/O多路复用就通过一种机制,可以监视多个描述符,一旦某个描述符就绪(一般是读就 ...