一开始题目没看清楚,以为是增加那条边后还有多少桥,所以就当做是无向图tarjan缩点后建树,然后求u,v的最近公共祖先,一直wa。

后来再看题目后才发现边放上去后不会拿下来了,即增加i条边后桥的数量。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <vector>
using namespace std;
const int maxn = 100100;
const int maxm = 200100; struct node{
int v,next;
}edge[maxm*2];
int head[maxn],low[maxn],dfn[maxn],fa[maxn],stack[maxn],in[maxn],vis[maxm*2];
int res[maxn][2],depth[maxn],father[maxn];
int n,m,id,clock,top,total,num,q;
void add_edge(int u,int v){
edge[id].v = v;edge[id].next = head[u];head[u] = id++;
edge[id].v = u;edge[id].next = head[v];head[v] = id++;
}
void init(){
memset(head,-1,sizeof(head));
memset(dfn,0,sizeof(dfn));
memset(fa,0,sizeof(fa));
memset(vis,0,sizeof(vis));
id = total = top = clock = num = 0;
int u,v;
while( m-- ){
scanf("%d%d",&u,&v);
add_edge(u,v);
}
}
void tarjan(int u){
low[u] = dfn[u] = ++clock;
stack[top++] = u;in[u] = 1;
for(int id = head[u]; id != -1; id = edge[id].next){
if( vis[id] )continue;//如果边以及走过,则不能再走了
vis[id] = vis[id^1] = 1;//标记边已经走过
int v = edge[id].v;
if(!dfn[v]){
tarjan(v);
if( dfn[u] < low[v])
{//将桥两端的顶点保存下来
res[total][0] = u;
res[total++][1] = v;
}
low[u] = low[v] < low[u] ? low[v] : low[u];
}
else if(in[v] && low[u] > dfn[v])low[u] = dfn[v];
}
if( dfn[u] == low[u]){
++num;//缩点
do{
int v = stack[--top];
fa[v] = num;
in[v] = 0;
}while( u != stack[top]);
}
} void dfs(int u,int dep){//确定个顶点的深度,以及其父亲节点
depth[u] = dep;
vis[u] = 1;
for(int id= head[u]; id != -1; id = edge[id].next){
int v = edge[id].v;
if(vis[v])continue;
father[v] = u;
dfs(v,dep+1);
}
}
int find(int x,int y){//递归找x,y的最近公共祖先
if(x == y)return x;
if(depth[x] > depth[y] )
{
if(!vis[x])total --;//当x所连的点为桥时,桥的数量减1
vis[x] = 1;
return find(father[x],y);
}
if(!vis[y])total --;
vis[y] = 1;
return find(x,father[y]);
}
void solve(){
int i;
tarjan(1);
int u,v;
memset(head,-1,sizeof(head));
id= 0;
for( i = 0 ; i < total; i++){//建树
u = fa[res[i][0]], v = fa[res[i][1]];
add_edge(u,v);
}
memset(vis,0,sizeof(vis));
father[1] = 1;
dfs(1,1);
}
int main(){
int u,v;
// freopen("in.txt","r",stdin);
int cas = 1;
while(~scanf("%d%d",&n,&m),n&&m){
init();
solve();
scanf("%d",&q);
printf("Case %d:\n",cas++);
memset(vis,0,sizeof(vis));
for(int i = 1; i <= q; i ++)
{
scanf("%d%d",&u,&v);
u = fa[u];v = fa[v];
find(u,v);
printf("%d\n",total);
}
puts("");
}
return 0;
}

  

POJ 3694 Network 无向图双联通+LCA的更多相关文章

  1. poj 3694 Network 边双连通+LCA

    题目链接:http://poj.org/problem?id=3694 题意:n个点,m条边,给你一个连通图,然后有Q次操作,每次加入一条边(A,B),加入边后,问当前还有多少桥,输出桥的个数. 解题 ...

  2. Poj 3694 Network (连通图缩点+LCA+并查集)

    题目链接: Poj 3694 Network 题目描述: 给出一个无向连通图,加入一系列边指定的后,问还剩下多少个桥? 解题思路: 先求出图的双连通分支,然后缩点重新建图,加入一个指定的边后,求出这条 ...

  3. POJ 3694——Network——————【连通图,LCA求桥】

    Network Time Limit:5000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Submit Stat ...

  4. POJ 3694 Network(无向图求桥+重边处理+LCA)

    题目大意: 给你一个无向图,然后再给你一个Q代表有Q次询问,每一次加一条边之后还有几座桥.在这里要对重边进行处理. 每次加入一条边之后,在这条搜索树上两个点的公共祖先都上所有点的桥都没了. 这里重边的 ...

  5. poj 3694 Network(双连通分量)

    题目:http://poj.org/problem?id=3694 #include <iostream> #include <cstring> #include <cs ...

  6. POJ 3694 Network(Tarjan求割边+LCA)

    Network Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 10969   Accepted: 4096 Descript ...

  7. hdu 2460 poj 3694 (双联通+LCA)

    在给出的两个点上加一条边,求剩下桥的数量,,不会LCA在线,就用了最普通的,先Tarjan双联通缩点,然后将缩完的图建成一棵树,树的所有边就是桥了,如果在任意两点间加一条边的话,那么从两点到最近公共祖 ...

  8. POJ3694 Network —— 边双联通分量 + 缩点 + LCA + 并查集

    题目链接:https://vjudge.net/problem/POJ-3694 A network administrator manages a large network. The networ ...

  9. POJ 3694Network(Tarjan边双联通分量 + 缩点 + LCA并查集维护)

    [题意]: 有N个结点M条边的图,有Q次操作,每次操作在点x, y之间加一条边,加完E(x, y)后还有几个桥(割边),每次操作会累积,影响下一次操作. [思路]: 先用Tarjan求出一开始总的桥的 ...

随机推荐

  1. Go组件学习——gorm四步带你搞定DB增删改查

    1.简介 ORM Object-Relationl Mapping, 它的作用是映射数据库和对象之间的关系,方便我们在实现数据库操作的时候不用去写复杂的sql语句,把对数据库的操作上升到对于对象的操作 ...

  2. JVM(二):画骨

    ### 概述 我们首先来认识一下`JVM`的运行时数据区域,如果说`JVM`是一个人,那么运行时数据区域就是这个人的骨架,它支撑着JVM的运行,所以我们先来学习一下运行时数据区域的分类和简单介绍. # ...

  3. thinkphp3.2使用七牛云上传文件

    最近项目中用到了七牛云服务,来分享一下thinkphp使用七牛云来进行文件上传 1.首先在七牛云创建一个空间,例如空间名为test.获取secrectKey,accessKey 2.在thinkphp ...

  4. grep使用集合

    一.grep使用 (一).选项 -a 不要忽略二进制数据. -A<显示列数> 除了显示符合范本样式的那一行之外,并显示该行之后的内容. -b 在显示符合范本样式的那一行之外,并显示该行之前 ...

  5. vagrant 创建虚拟机时遇到问题

    问题1 :  ceph-node3: Warning: Authentication failure. Retrying.. 问题分析: ssh 认证失败,在向虚拟机拷贝内容时权限不足. 解决办法: ...

  6. 如何阅读JDK源码

    JDK源码阅读笔记: https://github.com/kangjianwei/LearningJDK 如何阅读源码,是每个程序员需要面临的一项挑战. 为什么需要阅读源码?从实用性的角度来看,主要 ...

  7. Vue系列:为不同页面设置body背景颜色

    由于SPA页面的特性,传统的设置 body 背景色的方法并不通用. 解决方案:利用组件内的路由实现 代码参考如下

  8. Java——反射:运行时的类信息

    RTTI的使用 如果不知道某个对象的确切类型,RTTI会告诉我们,但是有一个限制:这个类型在编译时必须已知,这样才能使用RTTI识别它,并利用这些信息做一些有用的事情.  2.什么情况下需要反射 假设 ...

  9. Java实现ZooKeeper的zNode监控

    上一篇文章已经完成了ZooKeeper的基本搭建和使用的介绍,现在开始用代码说话.参考 https://zookeeper.apache.org/doc/current/javaExample.htm ...

  10. (二十九)c#Winform自定义控件-文本框(二)

    前提 入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章. 开源地址:https://gitee.com/kwwwvagaa/net_winform_custom_control ...