并查集+启发式合并+LCA思想 || 冷战 || BZOJ 4668
题面:bzoj炸了,以后再补发
题解:
并查集,然后对于每个点记录它与父亲节点联通的时刻 tim ,答案显然是 u 到 v 的路径上最大的 tim 值。启发式合并,把 size 小的子树往大的上并,可以证明树高是 log N 的(我不会),
所以最后套一个LCA思想,直接向上跳着找出路径上最大的 tim 值即为答案,时间复杂度O(N log N)。
代码:
#include<cstdio>
#include<iostream>
#define max(a,b) ((a)>(b)?(a):(b))
using namespace std;
inline int rd(){
int x=;char c=getchar();
while(c<''||c>'')c=getchar();
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x;
}
const int maxn=5e5+,maxm=5e5+;
int N,M,o,u,v,ans=,fa[maxn],tim[maxn],now=,f1,f2,siz[maxn];
int now_tim=;
inline int getf(int n){
if(fa[n]==n) return n;
return getf(fa[n]);
}
inline int getdep(int n){
int cnt=;
while(fa[n]!=n){
cnt++;
n=fa[n];
}
return cnt;
}
int main(){
N=rd(); M=rd();
for(int i=;i<=N;i++) fa[i]=i,siz[i]=;
while(M--){
o=rd(); u=rd(); v=rd();
u=u^ans; v=v^ans;
if(o==){
now_tim++;
f1=getf(u); f2=getf(v);
if(f1!=f2){
if(siz[f1]>siz[f2]) swap(f1,f2);
siz[f2]+=siz[f1];
fa[f1]=f2;
tim[f1]=now_tim;
}
}
else{
f1=getf(u); f2=getf(v);
ans=;
if(f1!=f2) {
printf("%d\n",ans);
continue;
}
int dep1=getdep(u),dep2=getdep(v);
if(dep1<dep2) swap(dep1,dep2),swap(u,v);
while(dep1>dep2){
dep1--;
ans=max(ans,tim[u]);
u=fa[u];
}
if(u!=v){
while(fa[u]!=fa[v]){
ans=max(ans,tim[u]);
ans=max(ans,tim[v]);
u=fa[u]; v=fa[v];
}
ans=max(ans,tim[u]);
ans=max(ans,tim[v]);
}
printf("%d\n",ans);
}
}
return ;
}
By:AlenaNuna
并查集+启发式合并+LCA思想 || 冷战 || BZOJ 4668的更多相关文章
- [BZOJ 4668]冷战(带边权并查集+启发式合并)
		
[BZOJ 4668]冷战(并查集+启发式合并) 题面 一开始有n个点,动态加边,同时查询u,v最早什么时候联通.强制在线 分析 用并查集维护连通性,每个点x还要另外记录tim[x],表示x什么时间与 ...
 - BZOJ 4668: 冷战 并查集启发式合并/LCT
		
挺好想的,最简单的方法是并查集启发式合并,加暴力跳父亲. 然而,这个代码量比较小,比较好写,所以我写了 LCT,更具挑战性. #include <cstdio> #include < ...
 - [HDU 3712] Fiolki (带边权并查集+启发式合并)
		
[HDU 3712] Fiolki (带边权并查集+启发式合并) 题面 化学家吉丽想要配置一种神奇的药水来拯救世界. 吉丽有n种不同的液体物质,和n个药瓶(均从1到n编号).初始时,第i个瓶内装着g[ ...
 - BZOJ2733[HNOI2012]永无乡——线段树合并+并查集+启发式合并
		
题目描述 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以从一个岛 到达 ...
 - BZOJ 3673: 可持久化并查集(可持久化并查集+启发式合并)
		
http://www.lydsy.com/JudgeOnline/problem.php?id=3673 题意: 思路: 可持久化数组可以用可持久化线段树来实现,并查集的查询操作和原来的一般并查集操作 ...
 - Codeforces 1166F 并查集 启发式合并
		
题意:给你一张无向图,无向图中每条边有颜色.有两种操作,一种是询问从x到y是否有双彩虹路,一种是在x到y之间添加一条颜色为z的边.双彩虹路是指:如果给这条路径的点编号,那么第i个点和第i - 1个点相 ...
 - [bzoj3123][sdoi2013森林] (树上主席树+lca+并查集启发式合并+暴力重构森林)
		
Description Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数 ...
 - 2018.08.21 bzoj4668: 冷战(并查集+启发式合并)
		
传送门 可以发现需要维护连通性和两点连通时间. 前者显然是并查集的常规操作,关键就在于如何维护两点的连通时间. 然后会想到这个时候不能用路径压缩了,因为它会破坏原本树形集合的结构,因此可以启发式按si ...
 - 51Nod 1515 明辨是非  —— 并查集 + 启发式合并
		
题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1515 1515 明辨是非 题目来源: 原创 基准时间限制:1 ...
 
随机推荐
- split切割.号的字符串
			
excel中的日期为下图所示,利用io读取到后,调试发现值为“12.10.2019”,需要将其转换为“2019-10-12” 用split方法以.号切割时,需要用转移字符“\\.”,代码如下 pack ...
 - [转]【JVM】调优笔记2-----JVM在JDK1.8以后的新特性以及VisualVM的安装使用
			
[From]https://www.cnblogs.com/sxdcgaq8080/p/7156227.html 隔壁的,加个引用做书签! [JVM]调优笔记2-----J ...
 - Android逆向——破解水果大战
			
最近公司需要测试安卓app安全,但安卓基本上0基础,决定开始学习下安卓逆向根据吾爱破解上教程 <教我兄弟学Android逆向系列课程+附件导航帖> https://www.52pojie. ...
 - jquery中this与$(this)的用法区别
			
jquery中this与$(this)的用法区别.先看以下代码: $("#textbox").hover( function() { this.title = "Test ...
 - Tensorflow 保存和载入训练过程
			
本节涉及点: 保存训练过程 载入保存的训练过程并继续训练 通过命令行参数控制是否强制重新开始训练 训练过程中的手动保存 保存训练过程前,程序征得同意 一.保存训练过程 以下方代码为例: import ...
 - 【JulyEdu-Python基础】第 6 课:高级面向对象
			
使用@property添加属性和自定义属性 __slots__和property 方法和属性的动态绑定 使用__slots__限定class实例能添加的属性 __slots__仅对当前类实例起作用,对 ...
 - elk 概念整理  集群状态 - yellow - 面试的问题  -- 官方配置文档 水平扩容以及数据保障
			
1. primary shard -- raid0 2.replicas shard -- raid1 3.index -- 图书馆的借书指引 4.MySQL vs elasticsearch # ...
 - PTA(Basic Level)1029.旧键盘
			
旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现.现在给出应该输入的一段文字.以及实际被输入的文字,请你列出肯定坏掉的那些键. 输入格式: 输入在 2 行中分别给出应该输入的文字.以及 ...
 - 什么是云数据库RDS PostgreSQL 版
			
PostgreSQL被业界誉为“最先进的开源数据库”,面向企业复杂SQL处理的OLTP在线事务处理场景,支持NoSQL数据类型(JSON/XML/hstore).支持GIS地理信息处理. 优点 NoS ...
 - HDU 2044 DP (fibonacci)
			
HDU 2044 https://vjudge.net/problem/HDU-2044 每一个只有可能由它左面的以及左上的状态变过来,也就是F(i-1)和F(i-2) F(1) = 1 F(2) = ...