BZOJ2049——[Sdoi2008]Cave 洞穴勘测
1、题目大意:就是一个动态维护森林联通性的题
2、分析:lct模板题
#include <stack>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
using namespace std;
#define LL long long
#define eps 1e-7
int n, m;
namespace LinkCutTree{
struct Node{
Node *ch[2], *fa;
bool rev;
Node(){
ch[0] = ch[1] = NULL;
fa = NULL;
rev = false;
}
inline int which(){
if(fa == NULL || (fa -> ch[0] != this && fa -> ch[1] != this)) return -1;
return fa -> ch[1] == this;
}
inline bool reverse(){
if(this) rev ^= 1;
}
inline void pd(){
if(rev){
swap(ch[0], ch[1]);
if(ch[0] != NULL) ch[0] -> reverse();
if(ch[1] != NULL) ch[1] -> reverse();
rev = false;
}
}
} ft[10010], *pos[10010];
inline void rotate(Node *o){
Node *p = o -> fa;
int l = o -> which(), r = l ^ 1;
o -> fa = p -> fa;
if(p -> which() != -1) p -> fa -> ch[p -> which()] = o;
p -> ch[l] = o -> ch[r];
if(o -> ch[r]) o -> ch[r] -> fa = p;
o -> ch[r] = p; p -> fa = o;
}
inline void splay(Node* o){
static stack<Node*> st;
if(!o) return;
Node* p = o;
while(1){
st.push(p);
if(p -> which() == -1) break;
p = p -> fa;
}
while(!st.empty()){
st.top() -> pd(); st.pop();
}
while(o -> which() != -1){
p = o -> fa;
if(p -> which() != -1){
if(p -> which() ^ o -> which()) rotate(o);
else rotate(p);
}
rotate(o);
}
}
inline void Access(Node* o){
Node* p = NULL;
while(o != NULL){
splay(o);
o -> ch[1] = p;
p = o; o = o -> fa;
}
}
inline void MovetoRoot(Node* o){
Access(o);
splay(o);
o -> reverse();
}
inline Node* FindRoot(Node* o){
while(o -> fa != NULL){
o = o -> fa;
}
return o;
}
inline void Link(Node* x, Node* y){
MovetoRoot(x);
x -> fa = y;
}
inline void Cut(Node* x, Node* y){
MovetoRoot(x);
Access(y);
splay(y);
x -> fa = NULL;
y -> ch[0] = NULL;
}
inline void init(){
for(int i = 1; i <= n; i ++) pos[i] = &ft[i];
}
inline void Connect(int u, int v){
Link(pos[u], pos[v]);
}
inline void Destroy(int u, int v){
Cut(pos[u], pos[v]);
}
inline bool Query(int u, int v){
return FindRoot(pos[u]) == FindRoot(pos[v]);
}
}
int main(){
char op[10];
int u, v;
scanf("%d%d", &n, &m);
LinkCutTree::init();
for(int i = 1; i <= m; i ++){
scanf("%s", op);
scanf("%d%d", &u, &v);
if(op[0] == 'C') LinkCutTree::Connect(u, v);
else if(op[0] == 'D') LinkCutTree::Destroy(u, v);
else puts(LinkCutTree::Query(u, v) ? "Yes" : "No");
}
return 0;
}
BZOJ2049——[Sdoi2008]Cave 洞穴勘测的更多相关文章
- BZOJ2049 SDOI2008 Cave 洞穴勘测 【LCT】
BZOJ2049 SDOI2008 Cave 洞穴勘测 Description 辉辉热衷于洞穴勘测.某天,他按照地图来到了一片被标记为JSZX的洞穴群地区.经过初步勘测,辉辉发现这片区域由n个洞穴(分 ...
- 【LCT】BZOJ2049 [SDOI2008]Cave 洞穴勘测
2049: [Sdoi2008]Cave 洞穴勘测 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 10059 Solved: 4863[Submit ...
- [BZOJ2049][Sdoi2008]Cave 洞穴勘测 LCT模板
2049: [Sdoi2008]Cave 洞穴勘测 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 9705 Solved: 4674[Submit] ...
- [bzoj2049][Sdoi2008]Cave 洞穴勘测_LCT
Cave 洞穴勘测 bzoj-2049 Sdoi-2008 题目大意:维护一个数据结构,支持森林中加边,删边,求两点连通性.n个点,m个操作. 注释:$1\le n\le 10^4$,$1\le m\ ...
- [BZOJ2049] [SDOI2008] Cave 洞穴勘测 (LCT)
Description 辉辉热衷于洞穴勘测.某天,他按照地图来到了一片被标记为JSZX的洞穴群地区.经过初步勘测,辉辉发现这片区域由n个洞穴(分别编号为1到n)以及若干通道组成,并且每条通道连接了恰好 ...
- BZOJ2049: [Sdoi2008]Cave 洞穴勘测 Link-Cut-Tree 模板题
传送门 搞了这么长时间Splay终于可以搞LCT了,等等,什么是LCT? $LCT$就是$Link-Cut-Tree$,是维护动态树的一个很高效的数据结构,每次修改和查询的均摊复杂度为$O(logN) ...
- bzoj2049: [Sdoi2008]Cave 洞穴勘测
lct入门题? 得换根了吧TAT 这大概不是很成熟的版本.. #include<iostream> #include<cstring> #include<cstdlib& ...
- bzoj2049 [Sdoi2008]Cave 洞穴勘测 link cut tree入门
link cut tree入门题 首先说明本人只会写自底向上的数组版(都说了不写指针.不写自顶向下QAQ……) 突然发现link cut tree不难写... 说一下各个函数作用: bool isro ...
- bzoj2049: [Sdoi2008]Cave 洞穴勘测 lct裸题
题意:三种操作一种摧毁一条边,一种链接一条边,一种查询两个点是否联通 题解:lct的link和cut即可 /********************************************** ...
随机推荐
- JS-计算器制作
不完善,接下来想着把运算符分开成一个一个的按钮... <!DOCTYPE html><html> <head> <meta charset="UTF ...
- uC/OS-II汇编代码
;*************************************************************************************************** ...
- css002 创建样式和样式表
创建样式和样式表 一个样式表包含多个样式 样式表的种类 1.内部样式表,存放在<head></head>之间.如: <head> <style> ( ...
- c#多态之抽象类与虚方法的异同点~
多态之抽象类与虚方法的相似点及不同点 : 不同点 1.方法关键字不一样 虚方法的方法关键字是:virtual. 抽象类的方法关键词是:abstract 2.基类的方法是否有方法体/实现 虚方法的方法: ...
- IIS------Http错误:50019,由于权限不足无法读取配置文件
转载: http://niutuku.com/tech/2008/273661.shtml 注意:该用户名称必须是:Everyone
- IIS------无法打开登录所请求的数据库 "company"。登录失败。 用户 'IIS APPPOOL\AppPool 4.0' 登录失败。
链接: http://www.cnblogs.com/VortexPiggy/archive/2013/04/06/3002055.html
- Java数据结构——迭代器
- Web Api系列教程第2季(OData篇)(一)——OData简介和一个小应用
第一季的链接以及系列导航:http://www.cnblogs.com/fzrain/p/3490137.html 在这里,首先要感谢Taiseer Joudeh不断的为我们带来最新的技术分享,楼主对 ...
- thinkphp删除
$result = M('content')->where('id>0')->delete $result =M('content')->where(array('id'=&g ...
- sql之truncate 、delete与drop区别
sql之truncate .delete与drop区别相同点:truncate 和不带 where 子句的 delete,以及 drop 一定会删除表内的数据不同点:1. truncate 和 del ...