Description
Input
Output
Sample Input
4 3 1 2 2 3 4 3
Sample Output
1 2 4 3
/*/ 拓扑排序裸题: 稍微加一个路径保存; 拓扑排序方法如下: (1)从有向图中选择一个没有前驱(即入度为0)的顶点并且输出它. (2)从网中删去该顶点,并且删去从该顶点发出的全部有向边. (3)重复上述两步,直到剩余的网中不再存在没有前驱的顶点或者所有的点都排序完毕为止. AC代码: /*/
#include"algorithm"
#include"iostream"
#include"cstring"
#include"cstdlib"
#include"string"
#include"cstdio"
#include"vector"
#include"cmath"
#include"queue"
using namespace std;
#define memset(x,y) memset(x,y,sizeof(x))
#define memcpy(x,y) memcpy(x,y,sizeof(x))
#define MX 1005
int map[MX][MX];
int indegree[MX];
int print[MX];
int main() {
int n,m,st,ed,cnt;
while(~scanf("%d%d",&n,&m)) {
memset(map,0);
memset(indegree,0);
memset(print,0);
for(int i=0; i<m; i++) {
scanf("%d%d",&st,&ed);
if(!map[st][ed]) {
map[st][ed]++;
indegree[ed]++;
}
}
for(cnt=1; cnt<=n;) {
int i;
for(i=1; i<=n; i++) {
if(!indegree[i])break;
}
indegree[i]=-1;
print[cnt++]=i;
int j;
for(j=1; j<=n; ++j) {
if(map[i][j]>0) {
indegree[j]--;
map[i][j]=-1;
}
}
}
int first=1;
for(int i=1; i<cnt; i++) {
if(first)first=0;
else printf(" ");
printf("%d",print[i]);
}
puts("");
}
return 0;
}
原文:http://www.cnblogs.com/HDMaxfun/p/5741918.html