Cod sursa(job #2680946)

Utilizator Andrei21AAnea Andrei Andrei21A Data 4 decembrie 2020 17:29:43
Problema Sortare topologica Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.67 kb
#include <fstream>
#include <vector>

using namespace std;

ifstream fin("sortaret.in");
ofstream fout("sortaret.out");

int n, m, x, y, p, nr;
vector <int> v[100005];
int viz[50005];
int a[50005];

void dfs(int h)
{
	int i;
	viz[h] = 1;
	for (i = 0; i < v[h].size(); i++)
	{
		if (!viz[v[h][i]])
		{
			dfs(v[h][i]);
	    }
	}
}

void Citire()
{
	fin >> n >> m;
	for (int i = 1; i <= m; i++)
	{
		fin >> x >> y;
		v[x].push_back(y);
	}
}

void Rezolvare()
{
	
	for (int i = 1; i <= n; i++)
	{
		if (!viz[i])dfs(i);
		while (i <= n)
		{
			if (viz[i] == 1)fout << i << " ";
			i++;
		}
	}
}


int main()
{
	Citire();
	Rezolvare();
}