博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ 2049 LCT
阅读量:5167 次
发布时间:2019-06-13

本文共 1673 字,大约阅读时间需要 5 分钟。

思路:LCT的基本操作

//By SiriusRen#include 
#include
#include
using namespace std;#define N 233333int n,m,xx,yy,rev[N];char op[11];struct Tree{
int l,r,where,num,fa;}t[N];void reverse(int k){
if(!k)return;rev[k]^=1;swap(t[k].l,t[k].r);}void pushdown(int k){
if(rev[k])reverse(t[k].l),reverse(t[k].r),rev[k]=0;}void zig(int k){ int f=t[k].fa;pushdown(f),pushdown(k); if(t[t[f].fa].l==f)t[t[f].fa].l=k;else if(t[t[f].fa].r==f)t[t[f].fa].r=k; t[k].fa=t[f].fa,t[f].l=t[k].r,t[t[f].l].fa=f,t[k].r=f;t[f].fa=k;}void zag(int k){ int f=t[k].fa;pushdown(f),pushdown(k); if(t[t[f].fa].l==f)t[t[f].fa].l=k;else if(t[t[f].fa].r==f)t[t[f].fa].r=k; t[k].fa=t[f].fa;t[f].r=t[k].l,t[t[f].r].fa=f;t[k].l=f;t[f].fa=k;}int splay_root(int k){
return t[k].fa&&(t[t[k].fa].l==k||t[t[k].fa].r==k);}void splay(int k){pushdown(k);while(splay_root(k))if(t[t[k].fa].l==k)zig(k);else zag(k);}int access(int k){
int now=0;while(k)splay(k),t[k].r=now,now=k,k=t[k].fa;return now;}void makeroot(int k){reverse(access(k)),splay(k);}void link(int k1,int k2){makeroot(k1),t[k1].fa=k2;access(k1);}void cut(int k1,int k2){makeroot(k1),access(k2),splay(k2),t[k2].l=t[k1].fa=0;}int findfa(int k){
while(t[k].fa)k=t[k].fa;return k;}int find(int k1,int k2){makeroot(k1);if(findfa(k2)==k1)return 1;return 0;}int main(){ scanf("%d%d",&n,&m); for(int i=1;i<=m;i++){ scanf("%s%d%d",op,&xx,&yy); if(op[0]=='Q'){ if(find(xx,yy))puts("Yes"); else puts("No"); } else if(op[0]=='C')link(xx,yy); else cut(xx,yy); }}

这里写图片描述

转载于:https://www.cnblogs.com/SiriusRen/p/6532131.html

你可能感兴趣的文章
TCP/IP 邮件的原理
查看>>
原型设计工具
查看>>
windows下的C++ socket服务器(4)
查看>>
css3 2d转换3d转换以及动画的知识点汇总
查看>>
【Java】使用Eclipse进行远程调试,Linux下开启远程调试
查看>>
对Vue为什么不支持IE8的解释之一
查看>>
计算机改名导致数据库链接的诡异问题
查看>>
Java8内存模型—永久代(PermGen)和元空间(Metaspace)(转)
查看>>
ObjectiveC基础教程(第2版)
查看>>
centos 引导盘
查看>>
Notes of Daily Scrum Meeting(12.8)
查看>>
Apriori算法
查看>>
onlevelwasloaded的调用时机
查看>>
求出斐波那契数组
查看>>
lr_start_transaction/lr_end_transaction事物组合
查看>>
CodeIgniter学习笔记(四)——CI超级对象中的load装载器
查看>>
.NET CLR基本术语
查看>>
ubuntu的home目录下,Desktop等目录消失不见
查看>>
建立,查询二叉树 hdu 5444
查看>>
[Spring框架]Spring 事务管理基础入门总结.
查看>>