poj 1094 拓扑排序
根据题目的要求,我们要每输入一次就要进行一次topo_sort。这样才能做到不成功时,能知道是哪步不成功,并且给出输出。还有要注意的就是如果我们可以提前判断结果了,但后面还有输入没完成,那么我们必须继续完成输入,不然剩下的输入会影响下一次case的输入。
这是我的第一道topo_sort的题目。发现naive topo_sort的算法不好理解啊,看了好多代码都没弄懂。。。最后看了joy_的这篇文章,才彻底的弄懂了。我都是参考他的代码来写的。再次谢谢他。加油加油,多做几题就会更熟练了。
#include <iostream> #include <fstream> using namespace std; #define MAXN 28 bool adj[MAXN][MAXN]; int in_degree[MAXN]; char str[MAXN]; int n,m; int topo_sort() { int i,j,k; bool flag=true; memset(in_degree,0,sizeof(in_degree)); memset(str,'\0',sizeof(str)); for(i=1; i<=n; i++) { for(j=1; j<=n; j++) if(adj[i][j]) in_degree[j]++; //入度加一 } for(i=1; i<=n; i++) //每次产生一个字符 { k=0; for(j=1; j<=n; j++) { if(in_degree[j]==0) { if(k==0) k=j; else flag=false; //还有入度为零的节点 } } if(k==0) return 0; //没有入度为零的节点,即存在环 in_degree[k]=-1; str[i-1]=k+'A'-1; for(j=1; j<=n; j++) //k指向的节点入度都减一,即去掉A及它相关的边 { if(adj[k][j]) in_degree[j]--; } } if(flag) return 1; //没有入度为零的点,完成排序 else return 2; //排序没有完成 } int main() { int i,a,b,result; char s[4]; freopen("acm.txt","r",stdin); while(scanf("%d%d",&n,&m),m+n) { memset(adj,false,sizeof(adj)); bool h=false; for(i=1; i<=m; i++) { scanf("%s",s); a=s[0]-'A'+1; b=s[2]-'A'+1; adj[a][b]=true; if(h) continue; //必须有,因为还要继续把剩下的数据都读完 result=topo_sort(); if(result==1) { printf("Sorted sequence determined after %d relations: %s.\n",i,str); h=true; } if(result==0) { printf("Inconsistency found after %d relations.\n",i); //有换存在 h=true; } } if(!h) printf("Sorted sequence cannot be determined.\n"); } return 0; }
我是一名在校大学生,热爱编程,虽然起步晚了些,但我会努力的。呵呵!
数据结构 算法