3 4 4 A B A C B C C D 4 4 A B A C B D C D 3 3 A B B A A C
ABCD No Answer No Answer
#include<cstdio>
#include<cstdlib>
#include<cstring>
using namespace std;
int map[110][110],is[110],n,count;
char ans[110];
int topo(){
int e,i,j=0,temp=0,u=0;
for(e=0;e<n;++e){
temp=0;u=0;
for(i=0;i<n;++i)
if(is[i]==0){
temp++;u=i;
}
if(temp>=2||temp==0)return 0;
ans[j++]=u+'A';
is[u]=-1;
for(int k=0;k<n;k++)
if(map[u][k]==1){
map[u][k]=0;
is[k]--;
}
}
ans[j]='\0';
return 1;
}
int main()
{
int k,i;
char a,b;
scanf("%d",&k);
while(k--){
scanf("%d%d",&n,&count);
memset(map,0,sizeof(map));
memset(is,0,sizeof(is));
getchar();
for(i=0;i<count;++i){
scanf("%c %c",&a,&b);
getchar();
map[a-'A'][b-'A']=1;
is[b-'A']++;
}
topo()?printf("%s\n",ans):printf("No Answer\n");
}
return 0;
}
原文:http://blog.csdn.net/r1986799047/article/details/42610095