BZOJ1123: [POI2008]BLO

Posted ~Silent

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了BZOJ1123: [POI2008]BLO相关的知识,希望对你有一定的参考价值。

题目大意:

给定一张无向图,求删去一个点以后有多少个有序点对不连通。

题解:
在Tarjan的过程中记录不能到达这个节点以上的子树和,统计答案。

代码:

#include<cstdio>
#include<algorithm>
using namespace std;
int n,m,ti,cnt,last[1000005],dfn[1000005],low[1000005],sz[1000005];
long long ans[1000005];
struct node{
	int to,next;
}e[1000005];
void add(int a,int b){
	e[++cnt].to=b;
	e[cnt].next=last[a];
	last[a]=cnt;
}
void Tarjan(int x,int fa){
	int cnt=0;
	dfn[x]=low[x]=++ti;
	sz[x]=1;
	for (int i=last[x]; i; i=e[i].next){
		int V=e[i].to;
		if (V==fa) continue;
		if (!dfn[V]){
			Tarjan(V,x);
			sz[x]+=sz[V];
			low[x]=min(low[x],low[V]);
			if (low[V]>=dfn[x]){
				ans[x]+=1ll*cnt*sz[V];
				cnt+=sz[V];
			}
		}
		else if (sz[V]) low[x]=min(low[x],dfn[V]);
	}
	ans[x]+=1ll*cnt*(n-cnt-1);
}
int main(){
	scanf("%d%d",&n,&m);
	for (int i=1; i<=m; i++){
		int x,y;
		scanf("%d%d",&x,&y);
		add(x,y);
		add(y,x);
	}
	Tarjan(1,0);
	for (int i=1; i<=n; i++)
		printf("%lld\n",(ans[i]+n-1)*2);
	return 0;
}

  

以上是关于BZOJ1123: [POI2008]BLO的主要内容,如果未能解决你的问题,请参考以下文章

BZOJ1123 [POI2008]BLO

bzoj1123: [POI2008]BLO(割点)

1123: [POI2008]BLO

BZOJ-1123BLO Tarjan 点双连通分量

[POI2008]BLO

[POI 2008] BLO