1. 程式人生 > >洛谷3950 部落衝突(LCT維護連通性)

洛谷3950 部落衝突(LCT維護連通性)

題目連結

看題目也是個比較裸的題目了
QWQ
不想多說了

開戰就是cutcut,停戰就是linklink

就當記錄一個板子了!

// 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 網絡 之前 傳送門 不得不說這題真是思路清奇,真是網絡流的一道好題,完全沒想到網絡流的建圖還可以這麽建 我們把每一個點拆成兩個點,分別表示白天和晚上,白天可以得到幹凈的餐巾(購買的,慢洗的,快洗的),