【NOIP2015】【Luogu2661】信息传递(有向图最小环)
【摘要】
problem
给定一张n个点,n条边的有向图求图的最小环,输出大小
solution
kosaraju暴力求出所有强连通分量,取最小值即可。
codes
//kosaraju
#include...
problem
- 给定一张n个点,n条边的有向图
- 求图的最小环,输出大小
solution
kosaraju暴力求出所有强连通分量,取最小值即可。
codes
//kosaraju
#include<iostream>
#include<algorithm>
#include<vector>
#define maxn 200010
using namespace std;
vector<int>G[maxn], rG[maxn];
vector<int>vs, cmp[maxn];
int vis[maxn], book[maxn], cnt;
void dfs(int u){
if(vis[u])return ;
vis[u] = 1;
for(int i = 0; i < G[u].size(); i++)dfs(G[u][i]);
//for(int i = 0; i < G[u].size(); i++)if(!vis[G[u][i]])dfs(G[u][i]);
vs.push_back(u);
}
void rdfs(int u){
//if(book[u])return ;
book[u] = cnt;
cmp[cnt].push_back(u);
for(int i = 0; i < rG[u].size(); i++)if(!book[rG[u][i]])rdfs(rG[u][i]);
//for(int i = 0; i < rG[u].size(); i++)rdfs(rG[u][i]);
}
int main(){
int n; cin>>n;
for(int i = 1; i <= n; i++){
int x; cin>>x;
G[i].push_back(x);
rG[x].push_back(i);
}
for(int i = 1; i <= n; i++)dfs(i);
for(int i = n-1; i >= 0; i--){
if(!book[vs[i]]){
++cnt;
rdfs(vs[i]);
}
}
int ans = 0xffffff;
for(int i = 1; i <= cnt; i++){
int si = cmp[i].size();
if(si != 0 && si != 1){
ans = min(ans, si);
}
}
cout<<ans<<"\n";
return 0;
}
文章来源: gwj1314.blog.csdn.net,作者:小哈里,版权归原作者所有,如需转载,请联系作者。
原文链接:gwj1314.blog.csdn.net/article/details/81676301
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)