-
Notifications
You must be signed in to change notification settings - Fork 10
/
topological_order.cpp
73 lines (68 loc) · 1.4 KB
/
topological_order.cpp
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
//Topological sort of vertex 1 to ... n
#include<bits/stdc++.h>
using namespace std;
#define pb push_back
#define pp pop_back
#define p pop
#define ps push
int main()
{
queue<int> gq;
vector<int> vertex[100];
int v,indegree[100];
int item;
cout<<"Enter the vertex :: ";
cin>>v;
cout<<"Enter adjacent element if present else enter -1\n";
for(int i=1;i<=v;i++)
{
int k;
cout<<"Enter the adjacent element of "<<i<<" :: ";
do
{
cin>>k;
if(k!=-1)
{
vertex[i].pb(k);
}
}while(k!=-1);
}
for(int i=1;i<=v;i++)
{
cout<<i<<" -- ";
for(auto it=vertex[i].begin();it!=vertex[i].end();it++)
{
cout<<*it<<" ";
}
cout<<endl;
}
memset(indegree,0,sizeof(indegree));
for(int i=1;i<=v;i++)
{
for(auto it=vertex[i].begin();it!=vertex[i].end();it++)
{
indegree[*it]++;
}
}
for(int i=1;i<=v;i++)
{
if(indegree[i]==0)
{
gq.ps(i);
}
}
while(!gq.empty())
{
item = gq.front();
cout<<item<<" ";
gq.p();
for(auto it=vertex[item].begin();it!=vertex[item].end();it++)
{
indegree[*it]--;
if(indegree[*it]==0)
{
gq.ps(*it);
}
}
}
}