achulkov2

Untitled

Apr 12th, 2018
61
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.85 KB | None | 0 0
  1. //
  2. // main.cpp
  3. // 2.B
  4. //
  5. // Created by Andrey Chulkov on 7/29/15.
  6. // Copyright (c) 2015 Andrey Chulkov. All rights reserved.
  7. //
  8.  
  9. #include <iostream>
  10. #include <vector>
  11. #include <set>
  12. #define m_p make_pair
  13. using namespace std;
  14. typedef pair<int, int> int_pair;
  15. vector<vector<int>> graph;
  16. vector<vector<int>> inversed_graph;
  17. vector<int_pair> edges;
  18. vector<int> components;
  19. vector<bool> used;
  20. vector<int> vertecies;
  21. int ncomp = 0;
  22.  
  23.  
  24. void dfs(int v) {
  25. used[v] = true;
  26. for (auto u : graph[v]) {
  27. if (!used[u]) {
  28. dfs(u);
  29. }
  30. }
  31. vertecies.push_back(v);
  32. }
  33.  
  34.  
  35. void rev_dfs(int v) {
  36. used[v] = true;
  37. components[v] = ncomp;
  38. for (auto u : inversed_graph[v]) {
  39. if (!used[u]) {
  40. rev_dfs(u);
  41. }
  42. }
  43. }
  44.  
  45. int main() {
  46. set<int_pair> condensed_edges;
  47. int n, m;
  48. cin >> n >> m;
  49. graph.assign(n, vector<int>());
  50. inversed_graph.assign(n, vector<int>());
  51. edges.resize(0);
  52. components.assign(n, 0);
  53. used.assign(n, false);
  54. vertecies.resize(0);
  55. for (int i = 0; i < m; i++) {
  56. int b_i, e_i;
  57. cin >> b_i >> e_i;
  58. graph[b_i - 1].push_back(e_i - 1);
  59. inversed_graph[e_i - 1].push_back(b_i - 1);
  60. edges.push_back(m_p(b_i - 1, e_i - 1));
  61. }
  62. for (int v = 0; v < n; v++) {
  63. if (!used[v]) {
  64. dfs(v);
  65. }
  66. }
  67. used.assign(n, false);
  68. for (int v = n - 1; v > -1; v--) {
  69. if (!used[vertecies[v]]) {
  70. ncomp += 1;
  71. rev_dfs(vertecies[v]);
  72. }
  73. }
  74. for (int i = 0; i < m; i++) {
  75. int u, v;
  76. u = components[edges[i].first];
  77. v = components[edges[i].second];
  78. if (u != v) {
  79. condensed_edges.insert(m_p(u, v));
  80. }
  81. }
  82. cout << (int) condensed_edges.size() << endl;
  83. return 0;
  84. }
Add Comment
Please, Sign In to add comment