UVA 10305 Ordering Tasks

UVA_10305

    这个题目就是一个纯拓扑排序的问题,具体理论和代码可以参考刘汝佳白书P111

#include<stdio.h>
#include
<string.h>
int n,st[110],top,G[110][110],vis[110];
void dfs(int u)
{
int v;
vis[u]
=1;
for(v=1;v<=n;v++)
if(G[u][v]&&!vis[v])
dfs(v);
st[
--top]=u;
}
int main()
{
int i,j,k,m,a,b;
while(1)
{
scanf(
"%d%d",&n,&m);
if(n==0)
break;
memset(G,
0,sizeof(G));
for(i=0;i<m;i++)
{
scanf(
"%d%d",&a,&b);
G[a][b]
=1;
}
memset(vis,
0,sizeof(vis));
top
=n;
for(i=1;i<=n;i++)
if(!vis[i])
dfs(i);
for(i=0;i<n;i++)
{
if(i)
printf(
" ");
printf(
"%d",st[i]);
}
printf(
"\n");
}
return 0;
}

  

原文地址:https://www.cnblogs.com/staginner/p/2172692.html