题意:给你一个无向图,可能有重边,有q次询问,问你每次我添加一条边,添加后这个图还有多少个桥

解题思路:首先先把所有没有割边的点对缩成一个联通块,无向图一般并查集判环,然后就得到一个割边树,给你一条新边,找到这条边两个端点的所属的联通块,如果这两个端点属于用一个联通块,那么没有作用,属于不同的联通块的时候,找到他们的lca,路径上有多少边,就减去多少割边,然后成为一个新的联通块,具体见代码

#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cstring>
using namespace std;
const int maxn=;
struct Edge
{
int next;int to;int id;
}edge[maxn<<];
int head[maxn],cnt,dfn[maxn],low[maxn];
int fa[maxn],pre[maxn],ans,step,n,m;
void init()
{
memset(head,-,sizeof(head));cnt=ans=step=;
for(int i=;i<=n;i++)
fa[i]=i;
memset(dfn,,sizeof(dfn));memset(low,,sizeof(low)); }
int findf(int u)
{
if(fa[u]==u)
return u;
else
{
fa[u]=findf(fa[u]);
return fa[u];
}
}
bool join(int x,int y)
{
int t1=findf(x);
int t2=findf(y);
if(t1==t2)
return false;
else
{
fa[t2]=t1;
return true;
}
}
void add(int u,int v,int id)//id是用来判是否有重边的
{
edge[cnt].next=head[u];edge[cnt].to=v;edge[cnt].id=id;head[u]=cnt++;
edge[cnt].next=head[v];edge[cnt].to=u;edge[cnt].id=id;head[v]=cnt++;
}
void tarjan(int u,int fa)
{
dfn[u]=low[u]=++step;
for(int i=head[u];i!=-;i=edge[i].next)
{
int v=edge[i].to;
int id=edge[i].id;
if(fa==id)
continue;
if(!dfn[v])
{
pre[v]=u;//记录他的父亲结点
tarjan(v,id);
low[u]=min(low[v],low[u]);
if(dfn[u]<low[v])
{
ans++;
}
else
{
join(u,v);//不是割边就合并
} }
else
{
low[u]=min(low[u],dfn[v]);
}
}
}
void lca(int u,int v)
{
if(findf(u)==findf(v))
return;
if(dfn[v]<dfn[u])//根据之前pre数组,从小的位置开始
swap(u,v);
while(dfn[v]>dfn[u])
{
if(join(pre[v],v))//路径上的割边全部合并
{
ans--;
}
v=pre[v];
}
while(u!=v)//如果是1的另一个子树中,因为上一段最多判到1,还需要判另一半
{
if(join(pre[u],u))
ans--;
u=pre[u];
}
}
int main()
{
int x,y;
int k,cot;
cot=;
while(scanf("%d%d",&n,&m)&&n&&m)
{
cot++;
init();
for(int i=;i<=m;i++)
{
scanf("%d%d",&x,&y);add(x,y,i);
}
tarjan(,);
pre[]=;
printf("Case %d:\n",cot);
scanf("%d",&k);
while(k--)
{
scanf("%d%d",&x,&y);
lca(x,y);
printf("%d\n",ans);
}
}
}

poj 3694(割边+lca)的更多相关文章

  1. Network POJ - 3694(lca并查集+连通图求桥)

    就是求出原先图中的桥的数量,在每一次询问时加入一条新边,求加入当前边后图中剩余的桥的数量 求出原先图中的桥的数量,然后减去新加入边的两端点之间的桥的数量,就是剩余桥的数量.. 用并查集把属于同一集合的 ...

  2. 【POJ 3694】 Network(割边&lt;桥&gt;+LCA)

    [POJ 3694] Network(割边+LCA) Network Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 7971 ...

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

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

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

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

  5. Tarjan算法各种&RMQ& POJ 3694

    关于tarjan 的思想可以在网上搜到,具体我也不太清楚,应该说自己理解也不深,下面是做题经验得到的一些模板. 其中有很多转载,包括BYVoid等,感谢让我转...望各路大神愿谅 有向图求连通分量的一 ...

  6. poj 3694 Network(割边+lca)

    题目链接:http://poj.org/problem?id=3694 题意:一个无向图中本来有若干条桥,有Q个操作,每次加一条边(u,v),每次操作后输出桥的数目. 分析:通常的做法是:先求出该无向 ...

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

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

  8. poj 3694 pku 3694 Network tarjan求割边 lca

    题意:给你一个连通图,然后再给你n个询问,每个询问给一个点u,v表示加上u,v之后又多少个桥.一个最容易想到的办法就是先加边找桥,加边找桥,这样可定超时.那么就可以缩点,因为如果一条边不是桥那么无论怎 ...

  9. poj 3694 Network 边双连通+LCA

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

随机推荐

  1. JDK源码分析(11)之 BlockingQueue 相关

    本文将主要结合源码对 JDK 中的阻塞队列进行分析,并比较其各自的特点: 一.BlockingQueue 概述 说到阻塞队列想到的第一个应用场景可能就是生产者消费者模式了,如图所示: 根据上图所示,明 ...

  2. Linux journalctl命令

    在Systemd出现之前,Linux系统及各应用的日志都是分别管理的,Systemd开始统一管理了所有Unit的启动日志,这样带来的好处就是可以只用一个 journalctl命令,查看所有内核和应用的 ...

  3. 基础概念PHP-FPM、FastCGI和CGI

    在搭建 LAMP/LNMP 服务器时,会经常遇到 PHP-FPM.FastCGI和CGI 这几个概念.如果对它们一知半解,很难搭建出高性能的服务器.接下来我们就以图形方式,解释这些概念之间的关系. 基 ...

  4. flex练习---纵横中文网

    采用 flexbox 弹性容器进行布局,只做练习用. 浏览器打开时切换到手机模式. 样本地址: http://tpl.zhuamimi.cn/%E6%89%8B%E6%9C%BA%E7%AB%AF%E ...

  5. 1.4 GPU分析

    shader  加宏   编译说明glsl

  6. 测者的测试技术手册:测试应该关注java.util.List.subList的坑

    java中有一个返回子列表的方法: public list<E> subList(int fromIndex, int toIndex){       subListRangeCheck( ...

  7. Scrapy 框架流程详解

    框架流程图 Scrapy 使用了 Twisted 异步非阻塞网络库来处理网络通讯,整体架构大致如下(绿线是数据流向): 简单叙述一下每层图的含义吧: Spiders(爬虫):它负责处理所有Respon ...

  8. 轻松学习UML之类图,状态图

    本文主要讲解UML图中的类图与状态图相关内容,如有不足之处,还请指正. 概述 统一建模语言(UML,UnifiedModelingLanguage)是面向对象软件的标准化建模语言,UML因其简单.统一 ...

  9. vue build报copy-webpack-plugin] unable to locate异常的解决方法

    ERROR in [copy-webpack-plugin] unable to locate 'J:\xxx\xxx\xxx\xxx\static' at 'J:\xxx\xxx\xxx\xxx\s ...

  10. Oracle 安装步骤、安装中错误处理、完整卸载

    /*************************************************以下ORACLE服务端安装************************************* ...