博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Tarjan-SCC-NOIP2015message
阅读量:6227 次
发布时间:2019-06-21

本文共 904 字,大约阅读时间需要 3 分钟。

This article is made by Jason-Cow.

Welcome to reprint.
But please post the writer's address.

连临街表都不用,每个节点的出度为1,数组搞定访问

#include 
#include
using namespace std;#define N 200010int GI(){ int x=0,c=getchar(),f=0; while(c<'0'||c>'9'){
if(c=='-')f=1;c=getchar();} while(c>='0'&&c<='9')x=x*10+c-'0',c=getchar(); return f?-x:x;}int dfn[N],low[N],s[N],in[N],idx,top,ans=1<<30,to[N];void tarjan(int u){ dfn[u]=low[u]=++idx; s[++top]=u,in[u]=1; int v=to[u]; if(!dfn[v])tarjan(v),low[u]=min(low[u],low[v]); else if(in[v]) low[u]=min(low[u],dfn[v]); if(low[u]==dfn[u]){ int sz=0; do++sz,in[top]=0; while(s[top--]!=u); if(sz>1)ans=min(ans,sz); }}int main(){ int n=GI(),u,v; for(v=1;v<=n;v++)to[v]=GI(); for(u=1;u<=n;u++)tarjan(u); return printf("%d",ans),0;}

转载于:https://www.cnblogs.com/JasonCow/p/6814579.html

你可能感兴趣的文章
基于http协议使用protobuf进行前后端交互
查看>>
bash腳本編程之三 条件判断及算数运算
查看>>
php cookie
查看>>
linux下redis安装
查看>>
弃 Java 而使用 Kotlin 的你后悔了吗?| kotlin将会是最好的开发语言
查看>>
JavaScript 数据类型
查看>>
量子通信和大数据最有市场突破前景
查看>>
对‘初学者应该选择哪种编程语言’的回答——计算机达人成长之路(38)
查看>>
如何申请开通微信多客服功能
查看>>
Sr_C++_Engineer_(LBS_Engine@Global Map Dept.)
查看>>
非监督学习算法:异常检测
查看>>
jquery的checkbox,radio,select等方法总结
查看>>
Linux coredump
查看>>
Ubuntu 10.04安装水晶(Mercury)无线网卡驱动
查看>>
Myeclipes快捷键
查看>>
ToRPC:一个双向RPC的Python实现
查看>>
我的友情链接
查看>>
nginx在reload时候报错invalid PID number
查看>>
神经网络和深度学习-第二周神经网络基础-第二节:Logistic回归
查看>>
Myeclipse代码提示及如何设置自动提示
查看>>