poj 1094(拓扑排序)

时间:2023-03-09 20:48:55
poj 1094(拓扑排序)

http://poj.org/problem?id=1094

题意:给你m个字母,有n个判断语句。求在哪个语句就可以判断出这个是不是一个环,或者在哪个语句可以判断出这些字母的排序规则,或者就是不能确定。

思路:每输入一次,进行一次排序,看会不会构成环或者已经可以确定了判断规则。

 #include <stdio.h>
#include <string.h> char ans[]; int indegree[]; bool mp[][]; int topsort(int n)
{
int i,j,m,flag,c=,tmp[],l=;
for(i=;i<n;i++)
tmp[i]=indegree[i];
for(i=;i<n;i++)
{
m=;
for(j=;j<n;j++)
if(tmp[j]==) {m++;flag=j;}
if(m==) return ; //如果全部的度都是0的话,那么说明有环。
ans[c++]=flag+'A';
if(m>) l=-; //这个不能用return -1,因为成环不一定是要成一个大环,可以几个字母成一个小环。
tmp[flag]--;
for(j=;j<n;j++)
if(mp[flag][j]) tmp[j]--;
}
return l;
} int main()
{
freopen("in.txt","r",stdin);
int m,n,sign;
char inp[];
while(scanf("%d%d",&m,&n),m||n)
{
memset(mp,false,sizeof(mp));
memset(indegree,,sizeof(indegree));
sign=;
for(int i=;i<=n;i++)
{
scanf("%s",inp);
if(sign) continue;
mp[inp[]-'A'][inp[]-'A']=true;
indegree[inp[]-'A']++;
int s=topsort(m);
if(s==)
{
printf("Inconsistency found after %d relations.\n",i);
sign=;
}
else if(s==)
{
printf("Sorted sequence determined after %d relations: ",i);
for(int j=;j<m;j++)
printf("%c",ans[j]);
printf(".\n");
sign=;
}
}
if(!sign)
printf("Sorted sequence cannot be determined.\n");
}
return ;
}