ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

Caocao's Bridges hdu-4738

2020-12-10 13:03:04  阅读:233  来源: 互联网

标签:Bridges hdu int rep memset Caocao dfn ans sizeof


题面

传送门

题解

缩点, 坑点在最小边为0是, 你至少用1个人去炸桥

代码

int n, m, _, k;
int h[N], ne[M << 1], to[M << 1], co[M << 1], tot;
int dfn[N], low[N], df, ans;

void add(int u, int v, int c) {
    ne[++tot] = h[u]; to[h[u] = tot] = v; co[tot] = c;
}

void tarjan(int x, int e) {
    dfn[x] = low[x] = ++df;
    for (int i = h[x]; i; i = ne[i]) {
        int y = to[i];
        if (!dfn[y]) { 
            tarjan(y, i); umin(low[x], low[y]);
            if (dfn[x] < low[y]) umin(ans, co[i]);
        }
        else if (i != (e ^ 1)) umin(low[x], dfn[y]);
    }
}

int main() {
    IOS; while (cin >> n >> m, n || m) {
        memset(dfn, 0, sizeof dfn); df = 0;
        memset(h, 0, sizeof h); tot = 1;
        rep (i, 1, m) {
            int u, v, c; cin >> u >> v >> c;
            add(u, v, c); add(v, u, c);
        } ans = 1e9;
        tarjan(1, -1); umax(ans, 1);
        rep (i, 2, n) if (!dfn[i]) { ans = 0; break; }
        cout << (ans == 1e9 ? -1 : ans) << '\n';
    }
    return 0;
}

标签:Bridges,hdu,int,rep,memset,Caocao,dfn,ans,sizeof
来源: https://www.cnblogs.com/2aptx4869/p/14113554.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有