UVA 11324 强连通分量 最长链

UVA 11324

题目链接:

https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=25&page=show_problem&problem=2299

题意:

给一个有向图,问最大的子图使得任意两点有路径可达。

思路:

1A啊!

求强连通缩点后具有最多结点的链即可。

源码:

#include <cstdio>

#include <cstring>

#include <cmath>

#include <cstdlib>

#include <algorithm>

#include <iostream>

#include <queue>

#include <vector>

#include <stack>

using namespace std;

#define gmax(a,b) ((a) > (b) ? (a) : (b))

#define gmin(a,b) ((a) < (b) ? (a) : (b))

const int MAXN = 1000 + 5;

int pre[MAXN], low[MAXN], dfs_clock;

stack<int>sta;

queue<int>que;

vector<int>lin[MAXN], lv[MAXN];

int sccno[MAXN], scc_cnt;

int n, m;

int num[MAXN], in[MAXN], val[MAXN];

void dfs_scc(int u)

{

    pre[u] = low[u] = ++dfs_clock;

    sta.push(u);

    for(int i = 0 ; i < (int)lin[u].size() ; i++){

        int v = lin[u][i];

        if(!pre[v]){

            dfs_scc(v);

            low[u] = gmin(low[u], low[v]);

        }

        else if(!sccno[v])

            low[u] = gmin(low[u], pre[v]);

    }

    if(low[u] == pre[u]){

        scc_cnt++;

        while(!sta.empty()){

            int org = sta.top();    sta.pop();

            sccno[org] = scc_cnt;

            num[scc_cnt]++;

            if(org == u)

                break;

        }

    }

}

void Tarjan()

{

    memset(pre, 0, sizeof(pre));

    memset(sccno, 0, sizeof(sccno));

    memset(num, 0, sizeof(num));

    dfs_clock = 0;

    scc_cnt = 0;

    while(!sta.empty()) sta.pop();

    for(int i = 1 ; i <= n ; i++)

        if(!pre[i]) dfs_scc(i);

}

void topo()

{

    for(int i = 1 ; i <= n ; i++)

        lv[i].clear();

    memset(in, 0, sizeof(in));

    for(int i = 1 ; i <= n ; i++){

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

            int u = i, v = lin[i][j];

            if(sccno[u] != sccno[v]){

                in[sccno[v]]++;

                lv[sccno[u]].push_back(sccno[v]);

            }

        }

    }

    memset(val, 0, sizeof(val));

    while(!que.empty()) que.pop();

    for(int i = 1 ; i <= scc_cnt ; i++)

        if(in[i] == 0)  que.push(i);

    while(!que.empty()){

        int org = que.front();  que.pop();

        for(int i = 0 ; i < (int)lv[org].size() ; i++){

            int v = lv[org][i];

            in[v]--;

            val[v] = gmax(val[v], val[org] + num[org]);

            if(!in[v])  que.push(v);

        }

    }

}

int main()

{

    int t;

    scanf("%d", &t);

    while(t--){

        scanf("%d%d", &n, &m);

        for(int i = 1 ; i <= n ; i++)

            lin[i].clear();

        int u, v;

        for(int i = 1 ; i <= m ; i++){

            scanf("%d%d", &u, &v);

            lin[u].push_back(v);

        }

        Tarjan();

        topo();

        int ans = 0;

//        for(int i = 1 ; i <= scc_cnt ; i++)

//            printf("num[%d] = %d\n", i, num[i]);

//        for(int i = 1 ; i <= scc_cnt ; i++)

//            printf("val[%d] = %d\n", i, val[i]);

//        for(int i = 1 ; i <= n ; i++)

//            printf("sccno[%d] = %d\n", i, sccno[i]);

        for(int i = 1 ; i <= scc_cnt ; i++)

            ans = gmax(ans, val[i] + num[i]);

        printf("%d\n", ans);

    }

    return 0;

}

 

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值