AIZU Online Judge Cycle Detection for a Directed Graph Solution
Problem Link: https://judge.u-aizu.ac.jp/onlinejudge/description.jsp?id=GRL_4_A
Solution in C++:
/// La ilaha illellahu muhammadur rasulullah
///******Bismillahir-Rahmanir-Rahim******///
/// Abul Hasnat Tonmoy
/// Department of CSE,23rd batch
/// Islamic University,Bangladesh
///**********ALLAH IS ALMIGHTY************///
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 9;
std::vector<int> g[N];
bool cycle;
int col[N];
void dfs(int u) {
col[u] = 1;
for (auto v : g[u]) {
if (col[v] == 0) {
dfs(v);
} else if (col[v] == 1) {
cycle = true;
}
}
col[u] = 2;
}
int32_t main() {
ios_base::sync_with_stdio(0);
cin.tie(0);
int n, m;
cin >> n >> m;
for (int i = 1; i <= m; i++) {
int u, v;
cin >> u >> v;
g[u].push_back(v);
}
cycle = false;
for (int i = 1; i <= n; i++) {
if (col[i] == 0) {
dfs(i);
}
}
cout << cycle << endl;
return 0;
}


No comments