zoukankan      html  css  js  c++  java
  • poj2367 Genealogical tree

    思路:

    拓扑排序,这里是用染色的dfs实现的。在有环的情况下可以判断出来,没有环的情况下输出拓扑排序序列。

    实现:

     1 #include <vector>
     2 #include <cstring>
     3 #include <iostream>
     4 #include <algorithm>
     5 #define w 0
     6 #define g 1
     7 #define b 2
     8 using namespace std;
     9 const int N = 105;
    10 int G[N][N];
    11 vector<int> res, vis;
    12 bool cycle;
    13 int n, m;
    14 void init()
    15 {
    16     cycle = false;
    17     cin >> n;
    18     memset(G, 0, sizeof G);
    19     for (int i = 0; i <= n; i++) vis.push_back(w);
    20     int x;
    21     for (int i = 1; i <= n; i++)
    22     {
    23         while (cin >> x, x)
    24         {
    25             G[i][x] = 1;
    26         }
    27     }
    28 }
    29 void dfs(int u)
    30 {
    31     if (vis[u] == b) return;
    32     if (vis[u] == g) { cycle = true; return; }
    33     vis[u] = g;
    34     for (int i = n; i >= 1; i--)
    35     {
    36         if (G[u][i]) dfs(i);
    37     }
    38     vis[u] = b;
    39     res.push_back(u);
    40     return;
    41 }
    42 void topsort()
    43 {
    44     for (int i = n; i >= 1; i--)
    45     {
    46         if (vis[i] == w) dfs(i);
    47     }
    48     reverse(res.begin(), res.end());
    49 }
    50 int main()
    51 {
    52     init();
    53     topsort();
    54     if (cycle) cout << "There is a cycle in G!" << endl;
    55     else
    56     {
    57         for (int i = 0; i < res.size(); i++)
    58             cout << res[i] << " ";
    59         cout << endl;
    60     }
    61     return 0;
    62 }
  • 相关阅读:
    Redis的探究
    白话插件框架原理
    Jquery文本框值改变事件兼容性
    HDU多校练习第一场4608——I_Number
    0-创建scott数据
    句柄和指针
    openssl编译(VC6.0)
    CrashRpt_v.1.4.2_vs2008_also_ok
    文件转换dll mingw
    qt windows分发工具使用(windoployqt)
  • 原文地址:https://www.cnblogs.com/wangyiming/p/7617959.html
Copyright © 2011-2022 走看看