洛谷3950 部落衝突(LCT維護連通性)
看題目也是個比較裸的題目了
QWQ
不想多說了
開戰就是,停戰就是
就當記錄一個板子了!
// luogu-judger-enable-o2
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
#include<queue>
#include<cmath>
#include<map>
#include<set>
using namespace std;
inline int read()
{
int x=0,f=1;char ch=getchar();
while (!isdigit(ch)) {if (ch=='-') f=-1;ch=getchar();}
while (isdigit(ch)) {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
const int maxn = 6e5+1e2;
int ch[maxn][3];
int fa[maxn],rev[maxn];
int st[maxn],n,m;
int size[maxn] ;
int son(int x)
{
if (ch[fa[x]][0]==x) return 0;
else return 1;
}
bool notroot(int x)
{
return ch[fa[x]][0]==x || ch[fa[x]][1]==x;
}
void reverse(int x)
{
swap(ch[x][0],ch[x][1]);
rev[x]^=1;
}
void pushdown(int x)
{
if (rev[x])
{
if (ch[x][0]) reverse(ch[x][0]);
if (ch[x][1]) reverse(ch[ x][1]);
rev[x]=0;
}
}
void rotate(int x)
{
int y=fa[x],z=fa[y];
int b=son(x),c=son(y);
if (notroot(y)) ch[z][c]=x;
fa[x]=z;
ch[y][b]=ch[x][!b];
fa[ch[x][!b]]=y;
ch[x][!b]=y;
fa[y]=x;
}
void splay(int x)
{
int y=x,cnt=0;
st[++cnt]=y;
while (notroot(y)) y=fa[y],st[++cnt]=y;
while (cnt) pushdown(st[cnt--]);
while (notroot(x))
{
int y=fa[x],z=fa[y];
int b=son(x),c=son(y);
if (notroot(y))
{
if (b==c) rotate(y);
else rotate(x);
}
rotate(x);
}
}
void access(int x)
{
for (int y=0;x;y=x,x=fa[x])
{
splay(x);
ch[x][1]=y;
}
}
void makeroot(int x)
{
access(x);
splay(x);
reverse(x);
}
int findroot(int x)
{
access(x);
splay(x);
while (ch[x][0])
{
pushdown(x);
x=ch[x][0];
}
return x;
}
void split(int x,int y)
{
makeroot(x);
access(y);
splay(y);
}
void link(int x,int y)
{
makeroot(x);
if (findroot(y)!=x)
{
fa[x]=y;
}
}
void cut(int x,int y)
{
split(x,y);
if (ch[x][1] || ch[x][0] || fa[x]!=y || ch[y][son(x)^1]) return;
fa[x]=ch[y][0]=0;
}
int u[maxn],v[maxn];
int tot;
int main()
{
n=read(),m=read();
for (int i=1;i<n;i++)
{
int u=read();
int v=read();
link(u,v);
}
for (int i=1;i<=m;i++)
{
char s[10];
scanf("%s",s+1);
if (s[1]=='Q')
{
int x=read(),y=read();
if (findroot(x)==findroot(y)) cout<<"Yes"<<"\n";
else cout<<"No"<<"\n";
}
if (s[1]=='C')
{
int x=read(),y=read();
u[++tot]=x;
v[tot]=y;
cut(x,y);
}
if (s[1]=='U')
{
int x=read();
link(u[x],v[x]);
}
}
return 0;
}
相關推薦
洛谷3950 部落衝突(LCT維護連通性)
題目連結 看題目也是個比較裸的題目了 QWQ 不想多說了 開戰就是cutcutcut,停戰就是linklinklink 就當記錄一個板子了! // luogu-judger-enable-o2 #include<iostream> #include&
【洛谷3950】部落衝突(LCT維護連通性)
點此看題面 大致題意: 給你一棵樹,\(3\)種操作:連一條邊,刪一條邊,詢問兩點是否聯通。 \(LCT\)維護連通性 有一道類似的題目:【BZOJ2049】[SDOI2008] Cave 洞穴勘測。 這兩道題都是\(LCT\)動態維護連通性的模板題。 考慮將\(x\)和\(y\)連邊時,我們就
洛谷P3950 部落衝突 LCT
Code: #include <cstdio> #include <algorithm> #include <string> #include <cstring> using namespace std; void setIO(string a)
洛谷4299首都(LCT維護動態重心+子樹資訊)
這個題目很有意思 QWQ 根據題目描述,我們可以知道,首都就是所謂的樹的重心,那麼我們假設每顆樹的重心都是\(root\)的話,對於每次詢問,我們只需要\(findroot(x)\)就可以。 那麼如何處理\(link\)操作呢QWQ 這裡是看了題解,我才知道是怎麼做的 大致的思想就是: !啟發式合併!
洛谷P3950 部落沖突 [LCT]
tdi == .org lct sel ros style 部落 () 題目傳送門 部落沖突 格式難調,體面就不放了。 分析: julao們應該都看得出來就是個$LCT$板子,戰爭就$cut$,結束就$link$,詢問就$find$。沒了。。。
【洛谷1501】[國家集訓隊] Tree II(LCT維護懶惰標記)
點此看題面 大致題意: 有一棵初始邊權全為\(1\)的樹,四種操作:將兩點間路徑邊權都加上一個數,刪一條邊、加一條新邊,將兩點間路徑邊權都加上一個數,詢問兩點間路徑權值和。 序列版 這道題有一個序列版:【洛谷3373】【模板】線段樹 2。 看題目就知道是一道線段樹板子題。 這種題目移到樹上路徑中
Cogs 2856. [洛谷U14475]部落沖突
文件 協議 splay size 允許 來源 || 二次 lin 2856. [洛谷U14475]部落沖突 ★★★ 輸入文件:lct.in 輸出文件:lct.out 簡單對比時間限制:1 s 內存限制:256 MB 【題目描述】 在一個叫做Tra
洛谷3348 大森林 (LCT + 虛點 + 樹上差分)
題目連結 這可真是道神仙題QWQ問了好多 d a l
2018.12.30【國家集訓隊】【洛谷P1903】數顏色 / 維護佇列(帶修莫隊)
傳送門 解析: 這道題好像以前在BZOJ上做過。 但是因為BZOJ資料較水,所以被我複雜度不對的程式碼搞過去了。。 真正的排序策略應該是這樣的: 塊大小設定成 n
洛谷上的C語言三連擊。
注意看題目,沒有0,一直錯。 #include<stdio.h> int panduan1(int num1,int num2, int num3); int main(){ int i, j, g; int num1, num2, num3; int p
三分法(洛谷3382 【模板】三分法)
printf log 含義 三分 tps ans 區間 bits int 如題,給出一個N次函數,保證在範圍[l,r]內存在一點x,使得[l,x]上單調增,[x,r]上單調減。試求出x的值。 輸入格式: 第一行一次包含一個正整數N和兩個實數l、r,含義如題目描述所示。
洛谷 P2827 蚯蚓(NOIp2016提高組D2T2)
mat 希望 c++ ffffff define fff 空行 特殊 到來 題目描述 本題中,我們將用符號?c?表示對c向下取整,例如:?3.0?=?3.1?=?3.9?=3。 蛐蛐國最近蚯蚓成災了!隔壁跳蚤國的跳蚤也拿蚯蚓們沒辦法,蛐蛐國王只好去請神刀手來幫他們消滅蚯蚓。
洛谷——P2722 總分 Score Inflation(背包)
cti 整數 () 每一個 class sample 計算 輸出格式 flat P2722 總分 Score Inflation 題目背景 學生在我們USACO的競賽中的得分越多我們越高興。 我們試著設計我們的競賽以便人們能盡可能的多得分,這需要你的幫助 題目描述
洛谷 P1581 A+B Problem(升級版)
就是 reg 一個 ack left void 輸出 思路 bad P1581 A+B Problem(升級版) 題目背景 小明這在寫作業,其中有一道A+B Problem ,他想啊想啊想,就是想不出來,於是就找到了會編程的你......
洛谷 P1401 城市(二分+網絡流)
const names 二分答案 網絡 con turn div mes strong 題目描述 N(2<=n<=200)個城市,M(1<=m<=40000)條無向邊,你要找T(1<=T<=200)條從城市1到城市N的路,使得
[洛谷U22157]刷水題(數位dp)(hash)
() class LG 取模 輸出格式 IT 接下來 ott scoi2012 題目背景 做正經題是不可能做正經題的,這輩子都不可能做正經題的,毒瘤題又不會做毒瘤題,就是水題這種東西,才維持了蒟蒻的信心; 題目描述 這裏有N+1 道水題,編號分別為
【POJ3621】【洛谷2868】Sightseeing Cows(分數規劃)
ring algo ++i names AD else gis top 最大 【POJ3621】【洛谷2868】Sightseeing Cows(分數規劃) 題面 Vjudge 洛谷 大意: 在有向圖圖中選出一個環,使得這個環的點權\(/\)邊權最大 題解 分數規劃 二分答
洛谷P2389 電腦班的裁員(區間DP)
color 轉移 一場 如果 一個點 輸入輸出 printf tdi turn 題目背景 隔壁的新初一電腦班剛考過一場試,又到了BlingBling的裁員時間,老師把這項工作交給了ZZY來進行。而ZZY最近忙著刷題,就把這重要的任務交(tui)給了你。 題目描述 ZZY有獨
洛谷P4012 深海機器人問題(費用流)
problem class spf int const 還得 一個點 png pty 傳送門 圖給的好坑……還得倒過來…… 用大佬的圖做個示範 我們考慮左圖吧 把每一個點向下連邊,容量$1$,費用為給
洛谷P1251 餐巾計劃問題(費用流)
empty code emp head != getc def 網絡 之前 傳送門 不得不說這題真是思路清奇,真是網絡流的一道好題,完全沒想到網絡流的建圖還可以這麽建 我們把每一個點拆成兩個點,分別表示白天和晚上,白天可以得到幹凈的餐巾(購買的,慢洗的,快洗的),