Pagini recente » Cod sursa (job #1412148) | Cod sursa (job #1164182) | Atasamentele paginii Clasament 777momento | Cod sursa (job #1502072) | Cod sursa (job #1447414)
#include<fstream>
#include<vector>
using namespace std;
ifstream fin("sortaret.in");
ofstream fout("sortaret.out");
vector<int> v[100005];
char f[100005];
int s[100005],dm[100005];
int vecin,k,n,m,a,b;
void dfs(int nod){
f[nod]=1;
for(int i=0;i<v[nod].size();i++){
vecin=v[nod][i];
if(f[vecin]==0){
dfs(vecin);
}
}
s[++k]=nod;
}
int i;
int main(){
fin>>n>>m;
for(i=1;i<=m;i++){
fin>>a>>b;
v[a].push_back(b);
dm[b]++;
}
for(i=1;i<=n;i++){
if(dm[i]==0){
dfs(i);
}
}
for(i=k;i>=1;i--){
fout<<s[i]<<" ";
}
return 0;
}