题解 POJ1094 【Sorting It All Out】
题目链接:Link
Problem
Solution
暴力枚举边数,用传递闭包判断当前状态即可。
Code
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<cassert>
using namespace std;
const int maxn=30;
int n,m,d[maxn][maxn],in[maxn];
char s[maxn][4];
int solve(int m)
{
memset(d,0,sizeof(d));
for(int i=1;i<=m;i++) d[s[i][0]-'A'+1][s[i][2]-'A'+1]=1;
for(int k=1;k<=n;k++)
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
d[i][j]|=d[i][k]&d[k][j];
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
if(d[i][j]&&d[j][i]) { printf("Inconsistency found after %d relations.\n",m); return 1; }
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) if(i!=j&&d[i][j]+d[j][i]==0) return 0;
printf("Sorted sequence determined after %d relations: ",m);
for(int i=1;i<=n;i++) for(int j=1;j<=n;j++) if(d[i][j]) in[j]++;
queue<int> Q;
for(int i=1;i<=n;i++) if(in[i]==0) Q.push(i);
assert(Q.size()==1);
while(Q.size())
{
int u=Q.front(); Q.pop();
printf("%c",char(u-1+'A'));
for(int i=1;i<=n;i++) if(d[u][i])
{
d[u][i]=0;
in[i]--;
if(in[i]==0) Q.push(i);
}
}
puts(".");
return 1;
}
int main()
{
#ifdef local
freopen("pro.in","r",stdin);
#endif
while(scanf("%d%d",&n,&m)==2&&n+m)
{
for(int i=1;i<=m;i++) scanf("%s",s[i]);
for(int i=1;i<=m;i++) if(solve(i)) goto nxt;
puts("Sorted sequence cannot be determined.");
nxt:continue;
}
return 0;
}
本作品由happyZYM采用知识共享 署名-非商业性使用-相同方式共享 4.0 (CC BY-NC-SA 4.0) 国际许可协议(镜像(简单版)镜像(完整版))进行许可。
转载请注明出处:https://www.cnblogs.com/happyZYM/p/11623915.html (近乎)全文转载而非引用的请在文首添加出处链接。