zoukankan      html  css  js  c++  java
  • 【NOIP2015】【Luogu2661】信息传递(有向图最小环)

    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<<"
    ";
        return 0;
    }
  • 相关阅读:
    题解 【洛谷】AT654
    题解【洛谷】CF134A
    jquery中select的应用
    Linq to xml 小例
    mongodb 使用场景和不使用场景
    一个面试题的解答-----从500(Id不连续)道试题库里随机抽取20道题!
    数据采集
    50款强力jquey,js 插件推荐
    node.js 学习
    wcf好文集合
  • 原文地址:https://www.cnblogs.com/gwj1314/p/10200102.html
Copyright © 2011-2022 走看看