一开始题目没看清楚,以为是增加那条边后还有多少桥,所以就当做是无向图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. abp(net core)+easyui+efcore实现仓储管理系统目录

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  2. 微服务SpringCloud之Spring Cloud Config配置中心Git

    微服务以单个接口为颗粒度,一个接口可能就是一个项目,如果每个项目都包含一个配置文件,一个系统可能有几十或上百个小项目组成,那配置文件也会有好多,对后续修改维护也是比较麻烦,就和前面的服务注册一样,服务 ...

  3. .net core web api部署到Linux系统CentOS 7

    一.创建一个.net core web api 的Demo 完成后的项目结构如图 修改下监听端口 发布代码 二.发布到CentOS 7上并运行 下一步需要一定的虚拟机知识了,我这里使用了windows ...

  4. 初试kafka消息队列中间件二(采用java代码收发消息)

    初试kafka消息队列中间件二(采用java代码收发消息) 上一篇 初试kafka消息队列中间件一 今天的案例主要是将采用命令行收发信息改成使用java代码实现,根据上一篇的接着写: 先启动Zooke ...

  5. mac下使用zerobrane调试cocos2dx的lua

    环境:MacOSx 10.9.2, Lua 5.1.4, luaSocket 2.0.2, xcode5.0.2 所需文件 luasocket-2.0.2.zip,ZeroBraneStudioEdu ...

  6. pdf.js跨域加载文件

    pdf.js一个基于Html的工具类,熟悉pdf.js的朋友们很清楚,pdf.js帮助我们做了很多事.尤其金融类网站会产生很多的报表.需要在线预览.pdf.js绝对是我们的首选 本地预览 在pdf.j ...

  7. Yii2 登录报错

    当用数据库登录系统报如下错误时 PHP Recoverable Error – yii\base\ErrorException Argument 1 passed to yii\web\User::l ...

  8. 盘一盘 NIO (二)—— Channel解析

    Channel是个啥? Channel,顾名思义,它就是一个通道.NIO中的所有IO都是从 Channel 开始的. Channel通道和流非常类似,主要有以下几点区别: 1.流是单向的,通道是双向的 ...

  9. springboot + jedisCluster

    如果使用的是redis2.x,在项目中使用客户端分片(Shard)机制. 如果使用的是redis3.x中的集群,在项目中使用jedisCluster. 1.项目结构 2.pom.xml 1 <? ...

  10. Vim高手,从来不用鼠标

    Vim脱离鼠标第一步 平时不可缺少的会用到vim,但是避免不了鼠标,事实上,省略鼠标是完全可以的,没有想像中那么难,看我短短几行带大家一起省略鼠标. 对了,vim有三种模式,基本模式就是用来输入命令的 ...