-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgraph_kosaraju.sublime-snippet
58 lines (55 loc) · 1.26 KB
/
graph_kosaraju.sublime-snippet
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
<snippet>
<content><![CDATA[
// kosaraju O(v+e)
// make adj and rev_adj
// part of main function
/*
vector<lint> order;
vector<lint> visited(n+1,0);
for(lint i=1;i<=n;i++)
{
if(visited[i]==0)
{
dfs1(adj,visited,i,order);
}
}
vector<lint> visited1(n+1,0);
for(lint i=n-1;i>=0;i--)
{
if(visited1[order[i]]==0)
{
vector<lint> scc;
dfs2(rev_adj,visited1,order[i],scc);
}
}
*/
//dfs for finding the order
void dfs1(vector<vector<lint>> &adj,vector<lint> &visited,lint s,vector<lint> &order)
{
if(visited[s]==1)
return;
visited[s]=1;
for(auto u:adj[s])
{
dfs1(adj,visited,u,order);
}
order.pb(s);
}
//dfs for collecting the scc nodes
void dfs2(vector<vector<lint>> &rev_adj,vector<lint> &visited1,lint s,vector<lint> &scc)
{
if(visited1[s]==1)
return;
visited1[s]=1;
for(auto u:rev_adj[s])
{
dfs2(rev_adj,visited1,u,scc);
}
scc.pb(s);
}
]]></content>
<!-- Optional: Set a tabTrigger to define how to trigger the snippet -->
<tabTrigger>graph_kosaraju</tabTrigger>
<!-- Optional: Set a scope to limit where the snippet will trigger -->
<!-- <scope>source.python</scope> -->
</snippet>