tarjan模板

//

//  main.cpp

//  Chapter 1

//

//  Created by chengzhi lin on 2018/3/6.

//  Copyright © 2018年 lczazu. All rights reserved.

//

#include <string>

#include <stack>

#include <iostream>

#include <vector>

#include <map>

#include <cstring>

#define MAXN 100005

using namespace std;


int _index;

int shelter[ MAXN ] = { 0 };

int polute[ MAXN ] = { 0 };

int vis_time = 0;

int cmp_num = 0;

int low[ MAXN ];

int dfn[ MAXN ];

vector<int> graph[ MAXN ];

vector<int> cmp[ MAXN ];

int in_cmp[ MAXN ];

int out_degree[ MAXN ] = { 0 };

bool in_stack[ MAXN ] = { 0 };

stack<int> sta;


void init( )

{

    memset( low, -1, sizeof( low ) );

    memset( dfn, -1, sizeof( dfn ) );

}


void tarjan( int x )

{

//    cout << "x " << x << endl;

    dfn[ x ] = low[ x ] = vis_time++;

    in_stack[ x ] = true;

    sta.push( x );

    

    for( int i = 0; i < graph[ x ].size( ); ++i )

    {

        int y = graph[ x ][ i ];

        

        if( dfn[ y ] == -1 )

        {

            tarjan( y );

            low[ x ] = min( low[ x ], low[ y ] );

        }

        else

        {

            if( in_stack[ y ] )

            {

                low[ x ]  = min( low[ x ], dfn[ y ] );

            }

        }

    }

    

    if( low[ x ] != dfn[ x ] )

    {

        return;

    }

    

    int y;

    do

    {

        y = sta.top( );

        sta.pop( );

        

        in_stack[ y ] = false;

        cmp[ cmp_num ].push_back( y );

        in_cmp[ y ] = cmp_num;

    }while( y != x );

    

    cmp_num++;

}


void add( int a, int b )

{

    graph[ a ].push_back( b );

}


void set_degree( )

{

    for( int i = 0; i < _index; ++i )

    {

        int temp = in_cmp[ i ];

        

        for( int j = 0; j < graph[ i ].size( ); ++j )

        {

            if( in_cmp[ graph[ i ][ j ] ] == temp )

            {

                continue;

            }

            

            ++out_degree[ temp ];

        }

    }

}

int main(int argc, const char * argv[]) {

    

    init( );

    for( int i = 0; i < _index; ++i )

    {

        if( dfn[ i ] == -1 )

        {

            tarjan( i );

        }

    }

    

    set_degree( );

    return 0;

}




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值