BZOJ_2594_[Wc2006]水管局长数据加强版_LCT
BZOJ_2594_[Wc2006]水管局长数据加强版_LCT
Description
Input
Output
Sample Input
1 2 2
2 3 3
3 4 2
1 4 2
1 1 4
2 1 4
1 1 4
Sample Output
2
3
【原题数据范围】
N ≤ 1000
M ≤ 100000
Q ≤ 100000
测试数据中宣布报废的水管不超过5000条;且任何时候我们考虑的水管网络都是连通的,即从任一结点A必有至少一条水管路径通往任一结点B。
【加强版数据范围】
N ≤ 100000
M ≤ 1000000
Q ≤ 100000
删边不如离线加边往里插。
类似魔法森林那道题,LCT维护权值最大的边,然后需要在加边的时候判断是否要加进去。
听起来非常简单,然而删边时不告诉你编号。。。
代码:
#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;
char nc() {
static char buf[100000],*p1,*p2;
return p1==p2&&(p2=(p1=buf)+fread(buf,1,100000,stdin),p1==p2)?EOF:*p1++;
}
inline int rd() {
register int x=0; register char s=nc();
while(s<'0'||s>'9')s=nc();
while(s>='0'&&s<='9')x=(x<<3)+(x<<1)+s-'0',s=nc();
return x;
}
#define N 100050
#define M 1100050
#define ls ch[p][0]
#define rs ch[p][1]
#define get(x) (ch[f[x]][1]==x)
int ch[M][2],f[M],val[M],rev[M],tot,mx[M],n,m,qs,fa[N];
int killx[M],killy[M],ans[M],nxt[M];
int find(int x) {
return fa[x]==x?x:fa[x]=find(fa[x]);
}
struct A {
int x,y,v,id,flg;
}e[M],ev[M];
bool cmp1(const A &x,const A &y) {
if(x.x==y.x) return x.y<y.y;
return x.x<y.x;
}
bool cmp2(const A &x,const A &y) {
return x.v<y.v;
}
struct QAQ {
int opt,x,y,pos;
}q[N];
inline bool isrt(int p) {
return ch[f[p]][0]!=p&&ch[f[p]][1]!=p;
}
inline void pushup(int p) {
mx[p]=p;
if(val[mx[ls]]>val[mx[p]]) mx[p]=mx[ls];
if(val[mx[rs]]>val[mx[p]]) mx[p]=mx[rs];
}
inline void pushdown(int p) {
if(rev[p]) {
swap(ch[ls][0],ch[ls][1]);
swap(ch[rs][0],ch[rs][1]);
rev[ls]^=1; rev[rs]^=1; rev[p]=0;
}
}
void update(int p) {
if(!isrt(p)) update(f[p]);
pushdown(p);
}
void rotate(int x) {
int y=f[x],z=f[y],k=get(x);
if(!isrt(y)) ch[z][ch[z][1]==y]=x;
ch[y][k]=ch[x][!k]; f[ch[y][k]]=y;
ch[x][!k]=y; f[y]=x; f[x]=z;
pushup(y); pushup(x);
}
void splay(int x) {
update(x);
for(int fa;fa=f[x],!isrt(x);rotate(x))
if(!isrt(fa))
rotate(get(fa)==get(x)?fa:x);
}
void access(int p) {
int t=0;
while(p) splay(p),rs=t,pushup(p),t=p,p=f[p];
}
void makeroot(int p) {
access(p); splay(p); swap(ls,rs); rev[p]^=1;
}
void link(int x,int p) {
makeroot(x); splay(p); f[x]=p;
}
void cut(int x,int p) {
makeroot(x); access(p); splay(p); ls=f[x]=0;
}
int query(int x,int p) {
makeroot(x); access(p); splay(p); return mx[p];
}
int search(int x,int y) {
int l=1,r=m+1;
while(l<r) {
int mid=(l+r)>>1;
if(x>e[mid].x) l=mid+1;
else r=mid;
}
r=nxt[x]+1;
while(l<r) {
int mid=(l+r)>>1;
if(y>e[mid].y) l=mid+1;
else r=mid;
}
return l;
}
int main() {
n=rd(); m=rd(); qs=rd();
register int i,x,y,dx,dy,tmp,d;
for(i=1;i<=m;i++) {
//e为x升序边便于二分
e[i].x=rd(),e[i].y=rd(),e[i].v=rd();
if(e[i].x>e[i].y) swap(e[i].x,e[i].y);
}
sort(e+1,e+m+1,cmp1);
for(i=1;i<=n;i++) fa[i]=i;
//ev为权值排序
for(i=1;i<=m;i++) ev[i]=e[i],nxt[e[i].x]=max(nxt[e[i].x],i)/*,printf("e[i].x=%d,nxt[e[i].x]=%d\n",e[i].x,nxt[e[i].x])*/;
for(i=1;i<=qs;i++) {
q[i].opt=rd(); q[i].x=rd(); q[i].y=rd();
if(q[i].opt==1) continue;
if(q[i].x>q[i].y) swap(q[i].x,q[i].y);
q[i].pos=search(q[i].x,q[i].y);
//printf("q[i].pos=%d ,q[i].x=%d ,q[i].y=%d\n",q[i].pos,q[i].x,q[i].y);
e[q[i].pos].flg=ev[q[i].pos].flg=1;
}
int tot=n,cnt=0;
sort(ev+1,ev+m+1,cmp2);
for(i=1;i<=m;i++) {
if(!ev[i].flg) {
int x=ev[i].x,y=ev[i].y;
int dx=find(x),dy=find(y);
if(dx!=dy) {
//printf("x=%d , y=%d\n",x,y);
tot++; val[tot]=ev[i].v; killx[tot]=x; killy[tot]=y; mx[tot]=tot;
link(x,tot); link(tot,y); fa[dx]=dy;
}
}
}
for(i=qs;i;i--) {
x=q[i].x; y=q[i].y;
if(q[i].opt==1) {
makeroot(x); access(y); splay(y);
ans[++cnt]=val[mx[y]];
}else {
int tmp=q[i].pos;
int dx=find(x),dy=find(y);
if(dx!=dy) {
tot++; val[tot]=e[tmp].v; killx[tot]=x; killy[tot]=y; mx[tot]=tot;
link(x,tot); link(tot,y); fa[dx]=dy;
}else {
int d=query(x,y);
if(val[d]>e[tmp].v) {
tot++; val[tot]=e[tmp].v; killx[tot]=x; killy[tot]=y; mx[tot]=tot;
cut(killx[d],d); cut(d,killy[d]); link(x,tot); link(tot,y);
}
}
}
}
for(i=cnt;i;i--) {
printf("%d\n",ans[i]);
}
}
BZOJ_2594_[Wc2006]水管局长数据加强版_LCT的更多相关文章
- BZOJ2594: [Wc2006]水管局长数据加强版
题解: 裸LCT+离线+二分+MST... 代码:(几乎摘抄自hzwer) #include<cstdio> #include<cstdlib> #include<cma ...
- bzoj 2594: [Wc2006]水管局长数据加强版 动态树
2594: [Wc2006]水管局长数据加强版 Time Limit: 25 Sec Memory Limit: 128 MBSubmit: 934 Solved: 291[Submit][Sta ...
- BZOJ 2594: [Wc2006]水管局长数据加强版( LCT )
离线然后就是维护加边的动态MST, Link cut tree秒掉..不过我写+调了好久...时间复杂度O(NlogN + MlogM) ------------------------------- ...
- [bzoj2594][Wc2006]水管局长数据加强版 (lct)
论蒟蒻的自我修养T_T.. 和noi2014魔法森林基本一样...然而数据范围大得sxbk...UPD:这题如果用lct判联通的话可能会被卡到O(mlogm)..所以最好还是用并查集吧 一开始数组开太 ...
- BZOJ 2594: [Wc2006]水管局长数据加强版 [LCT kruskal]
2594: [Wc2006]水管局长数据加强版 Time Limit: 25 Sec Memory Limit: 128 MBSubmit: 2917 Solved: 918[Submit][St ...
- [WC2006]水管局长数据加强版
Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一 ...
- 【刷题】BZOJ 2594 [Wc2006]水管局长数据加强版
Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一 ...
- 2594. [WC2006]水管局长数据加强版【LCT+最小生成树】
Description SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一 ...
- BZOJ2594 [Wc2006]水管局长数据加强版 【LCT维护最小生成树】
题目 SC省MY市有着庞大的地下水管网络,嘟嘟是MY市的水管局长(就是管水管的啦),嘟嘟作为水管局长的工作就是:每天供水公司可能要将一定量的水从x处送往y处,嘟嘟需要为供水公司找到一条从A至B的水管的 ...
随机推荐
- form表单提交转为可被 getModel(PROJECT.class ,null);接收
var form = new mini.Form("#editForm"+id); form.validate();if (!form.isValid()) { alert('信息 ...
- JeeSite
JeeSite是一个 开源的企业信息管理系统 基础框架.主要定位于"企业信息管理"领域,可用作企业信息管理类系统.网站后台管理类系统等.JeeSite是非常强调开发的高效性.健壮性 ...
- oracle to_date 函数
update pamsodt0p10 set cursysdate = to_date('2014-12-29 00:00:00','yyyy-mm-dd hh24:mi:ss') where cu ...
- java并发包分析之———AQS框架
一.什么是同步器 多线程并发的执行,之间通过某种 共享 状态来同步,只有当状态满足 xxxx 条件,才能触发线程执行 xxxx . 这个共同的语义可以称之为同步器.可以认为以上所有的锁机制都可以基 ...
- MySQL/MariaDB的锁
本文目录: 1.MariaDB/MySQL事务提交的方式 2.MariaDB/MySQL中的锁简介 2.1 不同存储引擎支持的锁级别 2.2 锁类型 2.3 锁兼容性 3.MyISAM的表级锁(loc ...
- spring的简单入门
spring是一个轻量级的JavaEE解决方案,是众多优秀设计模式的整合.spring的核心是:(工厂)容器 1.设计模式:解决一些特定问题的经典代码.共有23中设计模式(工厂,单例,代理,适配,装饰 ...
- MacOS多版本Python切换方案
1. 安装homebrew 官网 http://brew.sh/index_zh-cn.html 打开终端,在终端中粘贴如下脚本 /usr/bin/ruby -e "$(curl -fsSL ...
- IE条件注释,为IE单独写js
<!--[if IE ]> <body class="ie"> <![endif]--> <!--[if !IE]>--> & ...
- SpringCloud实战-Eureka
熟悉微服务架构或Dubbo框架的都知道,微服务中最核心.最基础的组件就是注册中心了.下面利用Spring Cloud Eureka实现服务注册中心.并注册一个简单的服务提供者. 首先先创建一个spir ...
- Html5列表元素
<ol> 有序列表: 属性:type(设置样式),reversed(倒序) <ul>无序列表 <li>表示列表中的项(在<ol>和<ul>中 ...