HDU6200 mustedge mustedge mustedge
建dfs树之后,在dfs树上加边其实就是让dfs树上一些边没有用了。(就这一点我想了很久才想到,真是zz啊)
//Serene
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdlib>
#include<cstdio>
#include<cmath>
#include<vector>
using namespace std;
const int maxn=1e5+10;
int T,n,m,Q; int aa,ff;char cc;
int read() {
aa=0;cc=getchar();ff=1;
while(cc<'0'||cc>'9') {
if(cc=='-') ff=-1;
cc=getchar();
}
while(cc>='0'&&cc<='9') aa=aa*10+cc-'0',cc=getchar();
return aa*ff;
} struct Edge{
int u,v;
}; vector<Edge> G; int fir[maxn],nxt[2*maxn],to[2*maxn],e=0;
void add(int x,int y) {
to[++e]=y;nxt[e]=fir[x];fir[x]=e;
to[++e]=x;nxt[e]=fir[y];fir[y]=e;
} int f[maxn];
int find(int x) {return x==f[x]? x:f[x]=find(f[x]);} int fa[maxn],size[maxn],son[maxn],dep[maxn];
void dfs1(int pos) {
size[pos]=1;int y,z;
for(y=fir[pos];y;y=nxt[y]) {
if((z=to[y])==fa[pos]) continue;
fa[z]=pos;dep[z]=dep[pos]+1;
dfs1(z);
size[pos]+=size[z];
if(size[z]>size[son[pos]]) son[pos]=z;
}
} int id[maxn],top[maxn],cnt;
void dfs2(int pos,int tp) {
id[pos]=++cnt; top[pos]=tp;
if(!son[pos]) return;
dfs2(son[pos],tp);
int y,z;
for(y=fir[pos];y;y=nxt[y]) {
if((z=to[y])==fa[pos]||to[y]==son[pos]) continue;
dfs2(z,z);
}
} int sz[maxn]; int q(int l,int r) {
int rs=0;l--;
while(r) { rs+=sz[r]; r-=(r&-r); }
while(l) { rs-=sz[l]; l-=(l&-l); }
return rs;
} void chge(int l,int r){
int rr;
for(r=find(r);r>=l;r=f[r]) {
rr=r;
while(rr<=n){ sz[rr]--; rr+=(rr&-rr); }
f[r]=find(r-1);
}
} void get_lca(int x,int y,int p) {
int rs=0;
while(top[x]!=top[y]) {
if(dep[top[x]]<dep[top[y]]) swap(x,y);
if(p) rs+=q(id[top[x]],id[x]);
else chge(id[top[x]],id[x]);
x=fa[top[x]];
}
if(x!=y) {
if(dep[x]<dep[y]) swap(x,y);
if(p) rs+=q(id[y]+1,id[x]);
else chge(id[y]+1,id[x]);
}
if(p) printf("%d\n",rs);
} int main() {
T=read();
int x,y,z,xx,yy;
for(int qaq=1;qaq<=T;++qaq) {
n=read();m=read(); G.clear(); e=0; cnt=0;
memset(fir,0,sizeof(fir));
memset(son,0,sizeof(son));
memset(fa,0,sizeof(fa));
for(int i=1;i<=n;++i) f[i]=i;
for(int i=1;i<=m;++i) {
x=read();y=read();
xx=find(x);yy=find(y);
if(xx!=yy) add(x,y),f[xx]=yy;
else G.push_back(Edge{x,y});
}
Q=read(); dep[1]=1;
dfs1(1); dfs2(1,1);
for(int i=1;i<=n;++i) f[i]=i;
for(int i=1;i<=n;++i) sz[i]=(i&-i);
z=G.size();
for(int i=0;i<z;++i) get_lca(G[i].u,G[i].v,0);
printf("Case #%d:\n",qaq);
for(int i=1;i<=Q;++i) {
x=read();y=read();z=read();
get_lca(y,z,x-1);
}
}
return 0;
}
除此之外,也可以用树状数组维护每个点到根的距离,然后每次修改就是把子树的区间-1,这样就是区间修改单点查询了。
不过还是要用并查集维护每条边上方第一个没有清零的边(有用的边)。
所以说这道题的重点就是避免重复的修改浪费时间,用并查集维护上方第一个没有清零的边。
HDU6200 mustedge mustedge mustedge的更多相关文章
- hdu6200 mustedge mustedge mustedge (并查集+dfs序树状数组)
题意 给定一个n个点m条边无向图(n,m<=1e5) 支持两个操作 1.添加一条边 2.询问点u到点v的所有路径中必经边的条数 操作数<=1e5 分析 第一眼看起来像是要动态维护无向图的边 ...
- hdu 6200 mustedge mustedge(并查集+树状数组 或者 LCT 缩点)
hdu 6200 mustedge mustedge(并查集+树状数组 或者 LCT 缩点) 题意: 给一张无向连通图,有两种操作 1 u v 加一条边(u,v) 2 u v 计算u到v路径上桥的个数 ...
- 【一坨理论AC的题】Orz sxy大佬
1.UVA10891 Game of Sum 2.LA4254 Processor . 3.UVA10905 Children's Game 4.UVA11389 The Bus Driver Pro ...
随机推荐
- Educational Codeforces Round49
A Palindromic Twist(字符串) 问每个字母必须向左或向右变成另一个字母,问能不能构成回文 #include <iostream> #include <string. ...
- angularjs 1 Failed to read the 'selectionStart' property from 'HTMLInputElement':
在找angularjs input(type='number')在获取焦点的时候,文本框内容选中效果,参考了:Select text on input focus,我直接复制他的code之后,在ion ...
- 企业网盘居然支持高速局域网文件传输工具(速度可达20M)
高速局域网文件传输工具Mobox,局域网内文件共享是公司内非常必须的功能,原本文件共享可以通过:1)windows目录共享目录来实现文件交互:2)通过U盘拷贝给对方:3)通过QQ发送给对方:4)通过邮 ...
- JAVA数据结构之数组
接下来的几篇博文会在最近仔细研读数据结构与算法的书籍后会摘录一些要点和总结一些自己的心得体会,帮助大家更深入地理解java中的数据结构和一些基本的算法,同时巩固自己数据结构和算法这些最基础的计算机知识 ...
- java.net.UnknownHostException 异常处理(转)
在linux系统下部署Java产品的集群环境时,后台报出如下异常,系统报找不到名为“QATest242”的主机: ERROR - Get local host name failed -com.tr ...
- Python的字符串修改报错:TypeError: 'str' object does not support item assignment
Python中想修改字符串的最后一个字符,使用name[-1] = 'e'来实现,运行后报错. 报错内容是:TypeError: 'str' object does not support item ...
- [JZOJ4788] 【NOIP2016提高A组模拟9.17】序列
题目 描述 题目大意 一个序列,每次可以使一段区间内的所有数加一(模四). 问最少的操作次数. 思考历程 一看这题目,诶,这不就是那道叫密码锁的题目吗? 然后随便打一打,样例过了,就再也没有思考这一题 ...
- Datagrip2019本地激活
一.下载: https://www.jetbrains.com/zh/datagrip/ 下载2019版本的(当前2019.1.2版本) 二.使用方法 1. 先下载压缩包解压后得到jetbr ...
- Angular CLI ng常用指令整理
一.组件创建 ng generate component heroes 二.运行项目 ng serve --open //--open 立即打开 三.创建指令 ng g directive my-ne ...
- JavaScript中字符串类型
字符串类型 字符串介绍 这是程序里面使用最为广泛的一-种类型.在JavaScript里面, 可以使用单引号,也可以使用双引号: 字符串这种数据类型非常霸道,它和其他数据类型相加都会被转换后才为字符串类 ...