POJ 3694 Network 无向图双联通+LCA
一开始题目没看清楚,以为是增加那条边后还有多少桥,所以就当做是无向图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的更多相关文章
- poj 3694 Network 边双连通+LCA
题目链接:http://poj.org/problem?id=3694 题意:n个点,m条边,给你一个连通图,然后有Q次操作,每次加入一条边(A,B),加入边后,问当前还有多少桥,输出桥的个数. 解题 ...
- Poj 3694 Network (连通图缩点+LCA+并查集)
题目链接: Poj 3694 Network 题目描述: 给出一个无向连通图,加入一系列边指定的后,问还剩下多少个桥? 解题思路: 先求出图的双连通分支,然后缩点重新建图,加入一个指定的边后,求出这条 ...
- POJ 3694——Network——————【连通图,LCA求桥】
Network Time Limit:5000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Submit Stat ...
- POJ 3694 Network(无向图求桥+重边处理+LCA)
题目大意: 给你一个无向图,然后再给你一个Q代表有Q次询问,每一次加一条边之后还有几座桥.在这里要对重边进行处理. 每次加入一条边之后,在这条搜索树上两个点的公共祖先都上所有点的桥都没了. 这里重边的 ...
- poj 3694 Network(双连通分量)
题目:http://poj.org/problem?id=3694 #include <iostream> #include <cstring> #include <cs ...
- POJ 3694 Network(Tarjan求割边+LCA)
Network Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 10969 Accepted: 4096 Descript ...
- hdu 2460 poj 3694 (双联通+LCA)
在给出的两个点上加一条边,求剩下桥的数量,,不会LCA在线,就用了最普通的,先Tarjan双联通缩点,然后将缩完的图建成一棵树,树的所有边就是桥了,如果在任意两点间加一条边的话,那么从两点到最近公共祖 ...
- POJ3694 Network —— 边双联通分量 + 缩点 + LCA + 并查集
题目链接:https://vjudge.net/problem/POJ-3694 A network administrator manages a large network. The networ ...
- POJ 3694Network(Tarjan边双联通分量 + 缩点 + LCA并查集维护)
[题意]: 有N个结点M条边的图,有Q次操作,每次操作在点x, y之间加一条边,加完E(x, y)后还有几个桥(割边),每次操作会累积,影响下一次操作. [思路]: 先用Tarjan求出一开始总的桥的 ...
随机推荐
- 【iOS】Updating local specs repositories
使用 Pods 时遇到这个问题,原因是被墙了……需换成下面命令: pod install --verbose --no-repo-update
- DVWA-SQL注入
SQL注入解题思路 寻找注入点,可以通过web扫描工具实现 通过注入点,尝试得到连接数据库的用户名,数据库名称,权限等信息. 猜解关键数据库表极其重要字段与内容. 通过获得的用户信息寻找后台进行登录. ...
- 【Java例题】5.1 多项式计算
1. 计算下列多项式的值. pn=an*x^n+...+a1*x+a0其中,"^"表示乘方. x.n以及ai(i=0,1,...,n-1)由键盘输入. package chapte ...
- react学习(二)--元素渲染
元素用来描述你在屏幕上看到的内容: const element = <h1>Hello, world</h1>; 与浏览器的 DOM 元素不同,React 当中的元素事实上是普 ...
- WEB基础(一)--JSP的9个内置对象
1.request request 对象是 javax.servlet.httpServletRequest类型的对象. 该对象代表了客户端的请求信息,主要用于接受通过HTTP协议传送到服务器的数据. ...
- Axure 使用 简单入门
1.Axure 简介 Axure是快速原型工具,简单来说就是把自己的web或app想法快速的展示出来的工具.具体信息百科:https://baike.baidu.com/item/axure%20rp ...
- 【POJ - 3616】Milking Time(动态规划)
Milking Time 直接翻译了 Descriptions 贝茜是一个勤劳的牛.事实上,她如此专注于最大化她的生产力,于是她决定安排下一个N(1≤N≤1,000,000)小时(方便地标记为0. ...
- [转载]关于ActiveMQ集群
转载于 http://blog.csdn.net/nimmy/article/details/6247289 近日因工作关系,在研究JMS,使用ActiveMQ作为提供者,考虑到消息的重要,拟采用Ac ...
- kpm字符串匹配算法
首先是简单的朴素匹配算法 /* * 返回子串t在主串s的位置,若不存在则返回0 */ public static int index(String s, String t) { int i = 0;/ ...
- iText实现pdf导出
/** * AsianTest.java */ import java.io.FileOutputStream; import java.io.IOException; import com.lowa ...