poj1094拓扑排序
Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 29539 | Accepted: 10233 |
Description
Input
Output
Sorted sequence determined after xxx relations: yyy...y.
Sorted sequence cannot be determined.
Inconsistency found after xxx relations.
where xxx is the number of relations processed at the time either a sorted sequence is determined or an inconsistency is found, whichever comes first, and yyy...y is the sorted, ascending sequence.
Sample Input
4 6 A<B A<C B<C C<D B<D A<B 3 2 A<B B<A 26 1 A<Z 0 0
Sample Output
Sorted sequence determined after 4 relations: ABCD. Inconsistency found after 2 relations. Sorted sequence cannot be determined.
Source
网上讲解参考代码
/** 这道题WA了好久,其中有几个需要注意的地方
1、当出现正好存在一种情况能够排序完所有节点时,不管以后的边会出现什么情况,都输出
能够排序成功
2、当中间的拓扑排序过程中出现多个几点的入度为0时,只记录当时的状态
(亦即该测试数据要么出现环,要么就是有多组解),不能立即返回,
要继续读边,直到能够排序完成(此时输出有多解的情况)或者出现环。
*/
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
bool G[30][30];
int d[30];
char s[30];
int n;
int toposort()
{
int num,k,i,j,t;
int td[30];
bool flag1=true;
for(i=1;i<=n;++i)
td[i]=d[i];
memset(s,0,sizeof(0));
for(j=0;j<n;++j)
{
num=0;
for(i=1;i<=n;++i)
{
if(td[i]==0)
{
k=i;
++num;
}
}
if(num==0) //有环
return -1;
if(num>1) //有多种情况,还需继续读边判断
{
flag1=false;
}
s[j]='A'+k-1;
td[k]--;
for(t=1;t<=n;++t)
{
if(G[k][t])
--td[t];
}
}
s[n]='\0';
if(flag1==false) //情况不唯一
return 0;
return 1; //全部排好序了返回1.
}
int main()
{
int m,i,ans,k;
bool flag;
char temp[5];
while(scanf("%d%d",&n,&m),m||n)
{
memset(G,false,sizeof(G));
memset(d,0,sizeof(d));
flag=true;
for(i=1;i<=m;++i)
{
scanf("%s",temp);
if(!flag) //已经排好序或者有环
continue;
int u=temp[0]-'A'+1;
int v=temp[2]-'A'+1;
if(!G[u][v])
{
++d[v];
G[u][v]=true;
}
ans=toposort();
if(ans==1||ans==-1)
{
k=i;
flag=false;
}
}
if(ans==1)
{
printf("Sorted sequence determined after %d relations: %s.\n",k,s);
}
else if(ans==-1)
{
printf("Inconsistency found after %d relations.\n", k);
}
else if(flag)
printf("Sorted sequence cannot be determined.\n");
}
return 0;
}
我的代码
#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
using namespace std;
int map[100][100];
int m,n;
int tindegree[100],indegree[100];
char str[5];
char s[39];
int toposort(){
bool flag=true;
memset(tindegree,0,sizeof(tindegree));
memset(s,0,sizeof(s));
for(int i=1;i<=n;i++){
tindegree[i]=indegree[i];
}
for(int i=1;i<=n;i++){
int sum=0,k;
for(int j=1;j<=n;j++){
if(!tindegree[j]){
k=j;
sum++;
}
}
if(sum==0){
return -1;
}
if(sum>1){
flag=false;
}
s[i-1]=k+'A'-1;
tindegree[k]--;
for(int z=1;z<=n;z++){
if(map[k][z]){
tindegree[z]--;
}
}
}
s[n]='\0';
if(flag==false)
return 0;
return 1;
}
int main(){
while(scanf("%d%d",&n,&m)!=EOF){
if(n==0&&m==0)
break;
memset(map,0,sizeof(map));
memset(indegree,0,sizeof(indegree));
memset(str,0,sizeof(str));
memset(s,0,sizeof(s));
int ans=2;
int temp;
bool flag=true;
for(int i=1;i<=m;i++){
scanf("%s",str);
if(flag==false)
continue;
int u=str[0]-'A'+1;
int v=str[2]-'A'+1;
if(!map[u][v]){
map[u][v]=1;
indegree[v]++;
}
ans=toposort();
if(ans==-1||ans==1){
temp=i;
flag=false;
}
}
if(ans==1)
printf("Sorted sequence determined after %d relations: %s.\n",temp,s);//temp不可以改为n
else if(ans==-1)
printf("Inconsistency found after %d relations.\n",temp);
else if(flag)
printf("Sorted sequence cannot be determined.\n");
}
return 0;
}