POJ3694-Network(Tarjan縮點+LCA)

來源:互聯網
上載者:User

標籤:max   題意   for   cto   vector   tar   20px   bool   color   

題目連結


題意:給你一個連通圖。然後再給你n個詢問,每一個詢問給一個點u,v表示加上u,v之後又多少個橋。

思路:用Tarjan縮點後,形成一棵樹,所以樹邊都是橋了。然後增加邊以後,查詢LCA,LCA上的橋都減掉。

代碼:

#include <iostream>#include <cstdio>#include <cstring>#include <vector>#include <utility>#include <algorithm>using namespace std;const int MAXN = 100005;struct Edge{    int to, next;}edge[MAXN * 5];int head[MAXN], tot;int Low[MAXN], DFN[MAXN];int Index, top;int bridge;int n, m;int f[MAXN], ancestor[MAXN];int find(int x) {    return x == f[x] ? x : f[x] = find(f[x]);}bool Union(int a, int b) {    int pa = find(a);    int pb = find(b);    if (pa != pb) {        f[pa] = pb;        return true;    }    return false;}void addedge(int u, int v) {    edge[tot].to = v;    edge[tot].next = head[u];    head[u] = tot++;}void Tarjan(int u, int pre) {    int v;    Low[u] = DFN[u] = ++Index;    for (int i = head[u]; i != -1; i = edge[i].next) {        v = edge[i].to;        if (v == pre) continue;         if (!DFN[v]) {            Tarjan(v, u);             ancestor[v] = u;            if (Low[u] > Low[v]) Low[u] = Low[v];            if (Low[v] > DFN[u])                 bridge++;              else                 Union(u, v);        }         else if (Low[u] > DFN[v])            Low[u] = DFN[v];    }}void init() {    memset(head, -1, sizeof(head));    memset(DFN, 0, sizeof(DFN));     tot = 0;    Index = top = 0;    bridge = 0;    memset(ancestor, 0, sizeof(ancestor));    for (int i = 1; i <= n; i++)        f[i] = i;}void solve() {    for (int i = 1; i <= n; i++)        if (!DFN[i])            Tarjan(i, -1);}void lca(int u, int v) {    while (u != v) {        while (DFN[u] >= DFN[v] && u != v) {            if (Union(u, ancestor[u]))                  bridge--;            u = ancestor[u];        }        while (DFN[v] >= DFN[u] && u != v) {            if (Union(v, ancestor[v]))                  bridge--;            v = ancestor[v];        }    }}int main() {    int t = 1;    while (scanf("%d%d", &n, &m)) {        if (n == 0 && m == 0) break;        init();         int u, v;          for (int i = 0; i < m; i++) {            scanf("%d%d", &u, &v);             addedge(u, v);            addedge(v, u);        }        solve();        printf("Case %d:\n", t++);        int k;        scanf("%d", &k);        while (k--) {            scanf("%d%d", &u, &v);             lca(u, v);            printf("%d\n", bridge);        }        printf("\n");    }    return 0;}


POJ3694-Network(Tarjan縮點+LCA)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.