Saturday, March 28, 2020

[UVA] 11183 - Teen Girl Squad

Author            : Dipu Kumar Mohanto 
                    CSE, Batch - 6
                    BRUR.
Problem Statement : 11183 - Teen Girl Squad
Source            : UVA Online Judge
Category          : Graph Theory
Algorithm         : Minimum Spanning Tree (Directed)
Verdict           : Accepted

  1. #include "bits/stdc++.h"  
  2. #include "ext/pb_ds/assoc_container.hpp"  
  3. #include "ext/pb_ds/tree_policy.hpp"  
  4.   
  5. using namespace std;  
  6. using namespace __gnu_pbds;  
  7.   
  8. template <typename T> using order_set = tree <T, null_type, less <T>, rb_tree_tag, tree_order_statistics_node_update>;  
  9.   
  10. #define ll               long long int  
  11. #define endl             '\n'  
  12. #define pii              pair <int, int>  
  13.   
  14. static const int max_node = 1e3 + 5; // Maximum number of Node  
  15. static const int max_edge = 1e5 + 5; // Maximum number of Edge  
  16. static const int inf      = 1e9 + 9;  
  17.   
  18. struct Edge  
  19. {  
  20.       int u, v, w;  
  21.       Edge(int u = 0, int v = 0, int w = 0)  
  22.             : u(u), v(v), w(w) {}  
  23. };  
  24.   
  25. vector <Edge> edges;  
  26.   
  27. int directed_mst(int root, int nv, int ne)  
  28. {  
  29. //      root = starting node  
  30. //      nv   = number of nodes, starting from 0  
  31. //      ne   = number of edges, starting from 0  
  32.   
  33.       vector <int> min_incoming(nv); // minimum weight among all incoming edges  
  34.       vector <int> pre(nv);          // parent of node v  
  35.       vector <int> cycle_id(nv);     // id of the corresponding cycle  
  36.       vector <int> vis(nv);          // used to determine cycle  
  37.       vector <Edge> tedges(ne);      // temporary edges, which will be changed during finding mst  
  38.   
  39.       tedges = edges;  
  40.       int dmst = 0;  
  41.       while (true)  
  42.       {  
  43.             for (int i = 0; i < nv; i++)  
  44.             {  
  45.                   min_incoming[i] = inf;  
  46.                   cycle_id[i] = -1;  
  47.                   vis[i] = -1;  
  48.             }  
  49.             for (int i = 0; i < ne; i++)  
  50.             {  
  51.                   int u = tedges[i].u;  
  52.                   int v = tedges[i].v;  
  53.                   int w = tedges[i].w;  
  54.                   if (u != v and w < min_incoming[v]) // Taking lowest incoming edge  
  55.                   {  
  56.                         min_incoming[v] = w;  
  57.                         pre[v] = u;  
  58.                   }  
  59.             }  
  60.             for (int i = 0; i < nv; i++)  
  61.             {  
  62.                   if (i == root) continue;  
  63.                   if (min_incoming[i] == inf) return -1; // Impossible case  
  64.             }  
  65.             min_incoming[root] = 0;  
  66.             pre[root] = root; // This need to set up, or can cause infinite loop  
  67.             int cnt_node = 0;  
  68.             for (int i = 0; i < nv; i++)  
  69.             {  
  70.                   dmst += min_incoming[i];  
  71.                   if (vis[i] == -1)  
  72.                   {  
  73.                         int v = i;  
  74.                         while (vis[v] == -1)  
  75.                         {  
  76.                               vis[v] = i;  
  77.                               v = pre[v];  // climbing up  
  78.                         }  
  79.                         if (v == root or vis[v] != i) continue;  
  80.                         cycle_id[v] = cnt_node; // new cycle, put all the member in same id  
  81.                         for (int u = pre[v]; u != v; u = pre[u]) cycle_id[u] = cnt_node;  
  82.                         cnt_node++;  
  83.                   }  
  84.             }  
  85.             if (cnt_node == 0) break;  
  86.             for (int i = 0; i < nv; i++)  
  87.             {  
  88.                   if (cycle_id[i] == -1) cycle_id[i] = cnt_node++;  
  89.             }  
  90.             for (int i = 0; i < ne; i++)  
  91.             {  
  92.                   int tmp = tedges[i].v;  
  93.                   tedges[i].u = cycle_id[ tedges[i].u ];  
  94.                   tedges[i].v = cycle_id[ tedges[i].v ];  
  95.                   if (tedges[i].u != tedges[i].v) tedges[i].w -= min_incoming[tmp];  
  96.             }  
  97.             nv = cnt_node;  
  98.             root = cycle_id[root];  
  99.       }  
  100.       return dmst;  
  101. }  
  102.   
  103.   
  104. signed main()  
  105. {  
  106.       ios_base::sync_with_stdio(false);  
  107.       cin.tie(nullptr);  
  108.   
  109.       #ifndef ONLINE_JUDGE  
  110.             freopen("in.txt""r", stdin);  
  111.       #endif // ONLINE_JUDGE  
  112.   
  113.       int tc;  
  114.       cin >> tc;  
  115.       for (int tcase = 1; tcase <= tc; tcase++)  
  116.       {  
  117.             int tnode, tedge;  
  118.             cin >> tnode >> tedge;  
  119.             edges.clear();  
  120.             edges.resize(tedge);  
  121.             for (Edge &x : edges) cin >> x.u >> x.v >> x.w;  
  122.             int dmst = directed_mst(0, tnode, tedge);  
  123.             cout << "Case #" << tcase << ": ";  
  124.             if (dmst == -1) cout << "Possums!" << endl;  
  125.             else cout << dmst << endl;  
  126.       }  
  127. }  

No comments:

Post a Comment

Note: Only a member of this blog may post a comment.