NOI模拟赛(3.13)Hike (远行)
Description
Input
第二行两个整数N,Q。
接下来Q行,每行先读入一个整数ty,若ty=1,则接下来读入两个整数u,v,表示小镇u与小镇v建立了一条新道路。若ty=2,读入一个整数u,表示Miranda要开始一次从小镇u出发的旅行。
注意:
若type=1,表示数据进行了加密。记lstans表示最近一次Miranda旅行的时间,那么对于每次操作的u或u,v,都要异或上lstans,即u=u ^ lstans,v=v ^ lstans。
若type=0,则不需要对数据进行处理。
Output
Sample Input
0
5 10
1 4 5
2 3
2 5
2 1
1 5 3
1 1 4
2 3
2 5
1 5 2
2 1
Sample Output
0
1
0
3
2
3
Data Constraint
对于50%的数据,满足:N<=100000,Q<=200000
另外有20%的数据,满足:type=0
对于100%的数据,满足:N<=300000,Q<=500000,type=0或1,解密后的u,v满足1<=u,v<=N,且道路的修建会满足:每一个时刻,都不存在u,v,使得u,v之间能通过多种方式到达
Solution
操作有加边和维护联通块的最远端点,可以用LCT做
抄标程的,根本不会写啊
复杂度为O((N+Q) log N)
#include <stdio.h>
#include <string.h>
#define rg register
#define dmax(a, b) ((a) > (b) ? (a) : (b)) inline int rd()
{
rg int x = 0, c = getchar(), f = 1;
for(; c < 48 || c > 57; c = getchar()) if(c == 45) f = -1;
for(; c > 47 && c < 58; c = getchar()) x = (x << 1) + (x << 3) + c - 48;
return x * f;
} inline void dswap(rg int &x, rg int &y)
{
x ^= y ^= x ^= y;
} const int N = 500010; int on_line, n, Q, bel[N], dia[N][2]; struct node
{
bool rev;
int sz, ch[2], fa;
}T[N]; int find(rg int x) {return bel[x] == x ? x : bel[x] = find(bel[x]);} inline void update(rg int u) {if(u) T[u].sz = T[T[u].ch[0]].sz + T[T[u].ch[1]].sz + 1;} inline bool is_root(rg int u) {rg int fa = T[u].fa; return !fa || !(T[fa].ch[0] == u || T[fa].ch[1] == u);} inline void setch(rg int u, rg int v, rg int c)
{
T[u].ch[c] = v;
if(v) T[v].fa = u;
} inline void mark(rg int u)
{
if(!u)return;
T[u].rev ^= 1;
dswap(T[u].ch[0], T[u].ch[1]);
} inline void down(rg int u)
{
if(!T[u].rev)return;
mark(T[u].ch[0]);
mark(T[u].ch[1]);
T[u].rev = 0;
} inline void rotate(rg int u)
{
int fa = T[u].fa, ft = T[fa].fa, c = T[fa].ch[1] == u;
T[u].fa = ft;
if(!is_root(fa)) setch(ft, u, T[ft].ch[1] == fa);
setch(fa, T[u].ch[!c], c);
setch(u, fa, !c);
update(fa);
} inline void splay(rg int u)
{
static int stack[N];
rg int top = 0, p = u;
for(; !is_root(p); p = T[p].fa) stack[++top] = p;
stack[++top] = p;
for(; top; top--) down(stack[top]);
for(; !is_root(u); rotate(u))
{
rg int fa = T[u].fa, ft = T[fa].fa;
if(is_root(fa)) continue;
((T[ft].ch[1] == fa) ^ (T[fa].ch[1] == u)) ? rotate(u) : rotate(fa);
}
update(u);
} inline int access(rg int u)
{
int nxt = 0;
for(; u; nxt = u, u = T[u].fa) splay(u), T[u].ch[1] = nxt, update(u);
return nxt;
} inline void make_root(rg int u) {mark(access(u));} inline void link(rg int u, rg int v)
{
make_root(v);
splay(v);
T[v].fa = u;
access(v);
} inline int get_dis(rg int u, rg int v)
{
make_root(u);
access(v);
splay(v);
return T[v].sz - 1;
} inline void merge(rg int a, rg int b)
{
rg int u = find(a), v = find(b);
bel[v] = u;
link(a, b);
rg int lu = dia[u][0], lv = dia[u][1], h = get_dis(dia[u][0], dia[u][1]);
rg int h1 = get_dis(dia[v][0], dia[v][1]);
if(h1 > h) lu = dia[v][0], lv = dia[v][1], h = h1;
for(rg int i = 0; i < 2; i++)
for(rg int j = 0; j < 2; j++)
{
h1 = get_dis(dia[u][i], dia[v][j]);
if(h1 > h) lu = dia[u][i], lv = dia[v][j], h = h1;
}
dia[u][0] = lu, dia[u][1] = lv;
} int main()
{
freopen("hike.in", "r", stdin), freopen("hike.out", "w", stdout);
on_line = rd(), n = rd(), Q = rd();
for(rg int i = 1; i <= n; i++) bel[i] = dia[i][0] = dia[i][1] = i;
rg int last_ans = 0;
while(Q--)
{
rg int ty = rd();
if(ty & 1)
{
rg int u = rd(), v = rd();
if(on_line) u ^= last_ans, v ^= last_ans;
merge(u, v);
}
else{
rg int u = rd();
if(on_line) u ^= last_ans;
rg int p = find(u);
printf("%d\n", last_ans = dmax(get_dis(u, dia[p][0]), get_dis(u, dia[p][1])));
}
}
fclose(stdin), fclose(stdout);
return 0;
}
NOI模拟赛(3.13)Hike (远行)的更多相关文章
- 小奇模拟赛9.13 by hzwer
2015年9月13日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿(explo) [题目背景] 小奇要开采一些矿物,它驾驶着一台带有钻头(初始能力值w)的飞船,按既定路线依次飞 ...
- NOI模拟赛 Day1
[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ...
- 6.28 NOI模拟赛 好题 状压dp 随机化
算是一道比较新颖的题目 尽管好像是两年前的省选模拟赛题目.. 对于20%的分数 可以进行爆搜,对于另外20%的数据 因为k很小所以考虑上状压dp. 观察最后答案是一个连通块 从而可以发现这个连通块必然 ...
- NOI 模拟赛 #2
得分非常惨惨,半个小时写的纯暴力 70 分竟然拿了 rank 1... 如果 OYJason 和 wxjor 在可能会被爆踩吧 嘤 T1 欧拉子图 给一个无向图,如果一个边集的导出子图是一个欧拉回路, ...
- 【2018.12.10】NOI模拟赛3
题目 WZJ题解 大概就是全场就我写不过 $FFT$ 系列吧……自闭 T1 奶一口,下次再写不出这种 $NTT$ 裸题题目我就艹了自己 -_-||| 而且这跟我口胡的自创模拟题 $set1$ 的 $T ...
- NOI模拟赛Day5
T1 有and,xor,or三种操作,每个人手中一个数,求和左边进行某一种运算的最大值,当t==2时,还需要求最大值的个数. test1 20% n<=1000 O(n^2)暴力 test2 2 ...
- NOI模拟赛Day4
看到成绩的时候我的内心** woc第一题写错了呵呵呵呵呵呵呵呵 人不能太浪,会遭报应的** ------------------------------------------------------ ...
- NOI模拟赛Day3
终于A题啦鼓掌~开心~ 开考看完题后,觉得第二题很好捏(傻叉上线 搞到十一点准备弃疗了然后突然发现我会做第一题 于是瞎码了码,就去准备饭票了... 好了,停止扯淡(就我一个我妹子每天不说话好难受QAQ ...
- NOI模拟赛Day2
深深的感受到了自己的水 ---------------------------------------------------------------------------------------- ...
随机推荐
- 关于 typedef struct 和 struct
举个例子说明:typedef struct abc{ int x; int y; int z;}ABC;是将结构体abc类型重新起个名字为ABC,以后再定义同一类型的变量时,可以写成:ABC m,n; ...
- adb shell getprop,setprop,watchprops更改,查看,监听系统属性
1.简介 每个属性都有一个名称和值,他们都是字符串格式.属性被大量使用在Android系统中,用来记录系统设置或进程之间的信息交换.属性是在整个系统中全局可见的.每个进程可以get/set属性. 在 ...
- python programming
1. super 2. *args, **kwargs 3. class object 4. type 5. isinstance 6. list[:] = another_list
- python tkinter窗口弹出置顶的方法
加上下面两句即可实现root窗口的置顶显示,可以用于某些程序的消息提示,能够弹出到桌面显示 root = Tk() root.wm_attributes('-topmost',1)
- Git命令---递归克隆
git clone --recursive https://github.com/rbgirshick/fast-rcnn.git Git命令 --recursive 会递归克隆fast-rcnn项目 ...
- Hacker的社交礼仪与自我修养【转】
Hacker School是位于纽约的一所特殊的编程“学校”,他们的目标是帮助参与者变成“更好的程序员”,之所以说他们特殊是因为这所“学校”没有老师,没有考试,也不会颁发证书,他们信奉三人行必有我师, ...
- 配置组件的 props
组件是相互独立.可复用的单元,一个组件可能在不同地方被用到.但是在不同的场景下对这个组件的需求可能会根据情况有所不同,例如一个点赞按钮组件,在我这里需要它显示的文本是“点赞”和“取消”,当别的同事拿过 ...
- AJPFX总结抽象类和接口的区别
/* * 抽象类和接口的区别 * 1.成员的区别 * ...
- AJPFX浅谈Java 性能优化之字符串过滤实战
★一个简单的需求 首先描述一下需求:给定一个 String 对象,过滤掉除了数字(字符'0'到'9')以外的其它字符.要求时间开销尽可能小.过滤函数的原型如下: String filter(Strin ...
- mysql索引原理及创建与查询
索引介绍 一:为什么要有索引 索引是用来优化查询效率(速度)的 没有索引的话,对于大数据的表,就只能每次都遍历一遍,数据量越大,耗时越多有索引的话,可以提升好几个数量级的速度 一般的应用系统,读写比例 ...