BZOJ3082: Graph2
LCT维护边被删除的时间的最大生成树,删边时若不在MST上则无视。
#include<bits/stdc++.h>
using namespace std;
const int N=250005;
int n,m,q,l1;
struct edge{int u,v,t;}c[N];
struct info{char c;int u,v;}f[N];
struct vec{
int u,v;
vec(int u=1e9,int v=0):u(u),v(v){}
};
bool operator<(vec a,vec b){
return a.u<b.u;
}
struct node;
typedef node*ptr;
struct node{
ptr i,j,p;
bool r;
vec v,s;
node();
ptr up(){
s=min(min(v,i->s),j->s);
return this;
}
void down(){
if(r)
i->r^=1,j->r^=1,swap(i,j),r=0;
}
}e[N];
node::node(){i=j=p=e;}
bool root(ptr o){return o!=o->p->i&&o!=o->p->j;}
void turn(ptr o){
ptr s=o->p,t=s->p;
if(!root(s))(s==t->i?t->i:t->j)=o;
s->p=o,o->p=t;
if(o==s->i)
s->i=o->j,o->j->p=s,o->j=s->up();
else
s->j=o->i,o->i->p=s,o->i=s->up();
}
void push(ptr o){
if(!root(o))push(o->p);
o->down();
}
ptr splay(ptr o){
push(o);
while(!root(o)){
if(!root(o->p))turn(o==o->p->i^o->p==o->p->p->i?o:o->p);
turn(o);
}
return o->up();
}
ptr exp(ptr o){
ptr s=e;
while(o!=e)splay(o)->j=s,s=o->up(),o=o->p;
return s;
}
void link(int i,int j){
exp(e+i)->r=1,splay(e+i)->p=e+j;
}
void cut(int i,int j){
ptr s=e+i,t=e+j;
exp(s)->r=1,exp(t);
if(s==t->i&&s->j==e)t->i=s->p=e;
if(t==s->j&&t->i==e)s->j=t->p=e;
}
bool jud(int i,int j){
exp(e+i)->r=1;
ptr o=exp(e+j);
while(o->i!=e)o=o->i,o->down();
return splay(o)==e+i;
}
void ins(int i){
if(c[i].u==c[i].v)return;
int&v=c[i].t;
if(!v)v=q+1;
e[n+i].v=vec(v,i);
if(!jud(c[i].u,c[i].v)){
link(c[i].u,n+i);
link(c[i].v,n+i);
}else{
int j=e[c[i].u].s.v;
if(c[i].t>c[j].t){
cut(c[j].u,n+j);
cut(c[j].v,n+j);
link(c[i].u,n+i);
link(c[i].v,n+i);
}
}
}
void del(int i){
cut(c[i].u,n+i);
cut(c[i].v,n+i);
}
int main(){
scanf("%d%d",&n,&m);
l1=m;
for(int i=1;i<=m;++i)
scanf("%d%d",&c[i].u,&c[i].v);
scanf("%d",&q);
for(int i=1;i<=q;++i){
scanf(" %c%d",&f[i].c,&f[i].u);
if(f[i].c=='D'){
int&v=c[f[i].u].t;
if(!v)v=i;
}else{
scanf("%d",&f[i].v);
if(f[i].c=='I')
c[++l1]=(edge){f[i].u,f[i].v};
}
}
for(int i=1;i<=m;++i)
ins(i);
l1=m;
for(int i=1;i<=q;++i){
if(f[i].c=='D')del(f[i].u);
if(f[i].c=='I')ins(++l1);
if(f[i].c=='Q')
puts(jud(f[i].u,f[i].v)?"Yes":"No");
}
}
BZOJ3082: Graph2的更多相关文章
- 带权图的最短路径算法(Dijkstra)实现
一,介绍 本文实现带权图的最短路径算法.给定图中一个顶点,求解该顶点到图中所有其他顶点的最短路径 以及 最短路径的长度.在决定写这篇文章之前,在网上找了很多关于Dijkstra算法实现,但大部分是不带 ...
- poj2612Mine Sweeper
很简单的模拟题目,但在队内赛的时候一直WA了10发...我ca 题目没看懂,也不算,就是我以为摸到地雷他会标星(*) ,但其实还是(x),T_T #include <cstdio> #in ...
- Jena TDB assembler syntax
1 introduction Assembler is a DSL of Jena to specify something to build, models and dataset, for exa ...
- SparkGraphXTest.scala
/** * Created by root on 9/8/15. */ import org.apache.spark._ import org.apache.spark.graphx._ impor ...
- CSS 实现三角形、梯形、等腰梯形
三角形 ; width: 0px; border-width: 0px 30px 45px 145px; border-style: none solid solid; border-color: t ...
- jsPlumb之流程图项目总结及实例
在使用jsPlumb过程中,所遇到的问题,以及解决方案,文中引用了<数据结构与算法JavaScript描述>的相关图片和一部分代码.截图是有点多,有时比较懒,没有太多的时间去详细的编辑. ...
- 【最短路+最大流】上学路线@安徽OI2006
目录 [最短路+最大流]上学路线@安徽OI2006 PROBLEM SOLUTION CODE [最短路+最大流]上学路线@安徽OI2006 PROBLEM 洛谷P4300 SOLUTION 先在原图 ...
- c++第三次实验
第一题: 先把代码贴上来 main.cpp #include <iostream> #include <cstdlib> #include<conio.h> #in ...
- C++实验三
part2 graph.h #ifndef GRAPH_H#define GRAPH_H// 类Graph的声明 class Graph { public: Graph(char ch, int n) ...
随机推荐
- [Codevs 1421]秋静叶&秋穣子(最大-最小博弈)
题目:http://codevs.cn/problem/1421/ 分析:有向树上的最大-最小博弈 先手与后手的策略不同: 先手A:让对方取得尽量少的前提下,自己取得尽量大 后手B:让自己取得尽量多的 ...
- Java--剑指offer(4)
16.输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. a)这里首先判断两个链表中有没有空表,这个就是依据表头是否为空.然后就是比较节点值的大小,然后就是使 ...
- 使用D3绘制图表(5)--水平柱状图表
绘制水平柱状图表的方法也不是很难,首先在svg中插入g,然后在g中插入rect. 1.html代码 <!DOCTYPE html> <html> <head> &l ...
- this Activity.this Activity.class
1. this 与 Activity.this this是你当前对象的引用,在你的例子中你肯定在内部类ClickEvent里面实现intent,他指向的是ClickEvent,而不是你要传入的Acti ...
- Android PNG透明图片转JPG格式背景变黑
Android PNG透明图片转JPG格式背景变黑 在上传图片是,需要把PNG格式转换成JPG格式的,但是在遇上透明背景时,转过来就变成黑色底图了! 原因是PNG支持透明图而 JPG格式不支持透明底 ...
- [转]Mybatis3.x与Spring4.x整合
原文地址:http://www.cnblogs.com/xdp-gacl/p/4271627.html 一.搭建开发环境 1.1.使用Maven创建Web项目 执行如下命令: mvn archetyp ...
- iOS开发--换肤简单实现以及工具类的抽取
一.根据美工提供的图片,可以有两种换肤的方案. <1>美工提供图片的类型一: <2>美工提供图片的类型二:这种分了文件夹文件名都一样的情况,拖入项目后最后用真实文件夹(蓝色文件 ...
- Spring_SpEL
一.本文目录 简单介绍SpEL的概念和使用 二.概念 Spring 表达式语言(简称SpEL):是一个支持运行时查询和操作对象图的强大的表达式语言.语法类似于 EL:SpEL ...
- 【BZOJ 2440】【中山市选 2011】完全平方数 莫比乌斯函数+容斥原理
网上PoPoQQQ的课件: •题目大意:求第k个无平方因子数 •无平方因子数(Square-Free Number),即分解之后所有质因数的次数都为1的数 •首先二分答案 问题转化为求[1,x]之间有 ...
- 关于php插件pdo_mysql的安装
今天在做一个商城的连接的时候,需要MpDO验证.需要安装pdo_mysql模块,刚开始按照php扩展模块的安装按照这个安装ZIP,curl都成功了但是安装pdo_mysql却不行,在./configu ...