From 3f4d26baf0d46d651976237c57e4545954d6ffbd Mon Sep 17 00:00:00 2001 From: Ravi Maurya <39462517+raviMaurya12@users.noreply.github.com> Date: Fri, 2 Oct 2020 15:54:19 +0530 Subject: [PATCH] Kosaraju's Algo for Strongly connected components --- Graphs/kosaraju.cpp | 86 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 86 insertions(+) create mode 100644 Graphs/kosaraju.cpp diff --git a/Graphs/kosaraju.cpp b/Graphs/kosaraju.cpp new file mode 100644 index 0000000..3a9f78a --- /dev/null +++ b/Graphs/kosaraju.cpp @@ -0,0 +1,86 @@ +#include +#define int long long +#define pb emplace_back +#define mp make_pair +#define tci(v,i) for(auto i=v.begin();i!=v.end();i++) +#define all(v) v.begin(),v.end() +#define rep(i,start,lim) for(long long (i)=(start);i<(lim);i++) +#define revrep(i,n) for(long long i=n-1;i>=0;i--) +#define boost ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0) +#define osit ostream_iterator output (cout," ") +#define pv(x) copy(all(x),output) +#define pa(a) rep(i,0,sizeof(a)/sizeof(a[0]))cout<>a[i] +#define getvec(vec,n) vi vec;int x;rep(i,0,n){cin>>x;vec.pb(x);} +#define sort_uniq(c) (sort(c.begin(), c.end()), c.resize(distance(c.begin(), unique(c.begin(), c.end())))) +#define uniq(a) a.resize(distance(a.begin(), unique(a.begin(), a.end()))) +#define dg(x) cout<<#x<<':'< vi; +typedef pair ii; +typedef vector vii; +template T gcd(T a,T b){if(a==0) return b; return gcd(b%a,a);} +int isPowerof2(int x) { return (x && !(x & x-1)); } + +vi adj[100]; +int visited[100]; +stack st; + +void dfs1(int s){ + visited[s]=1; + for(auto x:adj[s]){ + if(!visited[x])dfs1(x); + } + st.push(s); +} + +void dfs2(int s){ + visited[s]=1; + cout<>n>>m; + vii t; + rep(i,0,m){ + int x,y; + cin>>x>>y; + t.pb(mp(x,y)); + adj[x].pb(y); + } + rep(i,1,n+1){ + if(!visited[i]){ + dfs1(i); + } + } + rep(i,0,100){ + adj[i].clear(); + } + set0(visited); + rep(i,0,m){ + adj[t[i].s].pb(t[i].f); + } + while(!st.empty()){ + int el=st.top(); + st.pop(); + if(!visited[el]){ + dfs2(el); + cout<