使用Tarjan进行缩点无向图
int From[maxn],Laxt[maxn],To[maxn<<2],Next[maxn<<2],cnt;
int low[maxn],dfn[maxn],times,q[maxn],head,scc_cnt,scc[maxn];
vectorG[maxn];
int dis[maxn],S,T,ans;
void add(int u,int v)
{
Next[++cnt]=Laxt[u]; From[cnt]=u;
Laxt[u]=cnt; To[cnt]=v;
}
void tarjan(int u,int fa)
{
dfn[u]=low[u]=++times;
q[++head]=u;
for(int i=Laxt[u];i;i=Next[i]){
if(To[i]fa) continue;
if(!dfn[To[i]]) {
tarjan(To[i],u);
low[u]=min(low[u],low[To[i]]);
}
else low[u]=min(low[u],dfn[To[i]]);
}
if(low[u]dfn[u]){
scc_cnt++;
while(true){
int x=q[head--];
scc[x]=scc_cnt;
if(x==u) break;
}
}
}
void init()
{
memset(Laxt, 0, sizeof(Laxt));
cnt = 0;
}
int main()
{
init();
int N,M,u,v,i,j;
scanf("%d%d",&N,&M);
for(i=1;i<=M;i++){
scanf("%d%d",&u,&v);
add(u,v); add(v,u);
}
tarjan(1,0);
for(i=1;i<=N;i++){
for(j=Laxt[i];j;j=Next[j]){
if(scc[i]!=scc[To[j]])
G[scc[i]].push_back(scc[To[j]]);
}
}
return 0;
}
最新文章
- C++-Qt【2】-实现一个简单的记事本
- SQL性能优化案例分析
- django 自定义表单
- Visual Studio 2010配置Opencv2.4.9
- ExtJS MVC学习手记 2
- 关于web中的自适应布局
- PHP开发搜索引擎技术全解析
- iOS/object-c: 枚举类型 enum,NS_ENUM,NS_OPTIONS
- Java文件操作二:File文件的方法
- CentOS7.0 安装JAVA周围环境
- CentOS 引导 Win10 启动项
- 我是怎么知道 PTHREAD_MUTEX_INITIALIZER 是什么鬼东西的 ??
- Nodejs+MQTT
- 渗透测试_利用Burp爆破用户名与密码
- 多级分类标签{dede:channelartlist}实现当前栏目颜色高亮显示
- [hdu P4114] Disney&#39;s FastPass
- Lombok(1.14.8)的简单示例
- Bzoj5332: [Sdoi2018]旧试题
- grep与正则表达式的使用
- angular的uiRouter服务学习(2)