Pagini recente » Cod sursa (job #2357007) | Cod sursa (job #2933563) | Cod sursa (job #1685382) | Cod sursa (job #219348) | Cod sursa (job #1038346)
#include<fstream>
#define NMAX 10000
using namespace std;
ifstream fin("ctc.in");
ofstream fout("ctc.out");
/*
//varianta 1
int D[NMAX][NMAX],n,viz[NMAX],m,x,y;
void citire()
{
int i,j;
fin>>n>>m;
for(i=1;i<=m;i++)
{
fin>>x>>y;
D[x][y]=1;
}
}
void construire()
{
int i,j,k;
for(k=1;k<=n;k++)
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
if(D[i][k] && D[k][j])
D[i][j]=1;
}
void rezolvare(int x)
{
int i,j;
for(j=1;j<=n;j++)
{
if(viz[j]==0)
{
viz[j]=1;
fout<<j<<" ";
for(i=1;i<=n;i++)
{
if(D[j][i]==1 && D[i][j]==1 && viz[i]==0)
{
viz[i]=1;
fout<<i<<" ";
}
}
fout<<"\n";
}
}
}
int main()
{
citire();
construire();
rezolvare(1);
}*/
//varianta 3
int n,m,i,nrp;
int G[NMAX][NMAX],GT[NMAX][NMAX];
int postordine[NMAX],viz[NMAX];
void citire()
{
int x,y;
fin>>n>>m;
for(i=1;i<=m;i++)
{
fin>>x>>y;
G[x][y]=1;
GT[y][x]=1;
}
}
void DFS(int x)
{
int St[NMAX],k,v,y;
St[1]=x;
viz[x]=1;
k=1;
while(k)
{
v=St[k];
y=0;
for(i=1;i<=n;i++)
{
if(G[v][i] && viz[i]==0)
{
y=i;
postordine[++nrp]=i;
break;
}
}
if(y==0) k--;
else
{
viz[y]=1;
St[++k]=y;
}
}
}
void DFST(int x)
{
int St[NMAX],k,v,y;
St[1]=x;
viz[x]=1;
fout<<x<<" ";
k=1;
while(k)
{
v=St[k];
y=0;
for(i=1;i<=n;i++)
{
if(GT[v][i] && viz[i]==0)
{
y=i;
break;
}
}
if(y==0) k--;
else
{
viz[y]=1;
fout<<y<<" ";
St[++k]=y;
}
}
}
int main()
{
citire();
for(i=1;i<=n;i++)
{
if(viz[i]==0)
DFS(i);
}
for(i=1;i<=n;i++) viz[i]=0;
for(i=nrp;i>=1;i--)
{
if(viz[i]==0)
DFST(postordine[i]);
fout<<"\n";
}
return 0;
}