首页 > 其他 > 详细

POJ1094拓扑排序

时间:2014-07-16 18:40:25      阅读:253      评论:0      收藏:0      [点我收藏+]

每次输入的时候 进行一次 拓扑排序。 拓扑排序时,每次查找入度为零的点只有一个,则此解为确定解。若找到确定解之后出现环(坑),继续输入,不管它。

#include <cstdio>
#include <cstring>
#include <algorithm>
#include <climits>
#include <string>
#include <iostream>
#include <map>
#include <cstdlib>
#include <list>
#include <set>
#include <queue>
#include <stack>

using namespace std;


int main()
{
    //freopen("in.txt","r",stdin);
   // freopen("out.txt","w",stdout);
    int n,m;char str[100];
    int vis[100];int G[100][100];
    int in[100],in1[100];
    int topo[100];
    while(cin>>n>>m,n||m){
        memset(G,0,sizeof(G));
        memset(in,0,sizeof(in));
        int flag=1;int ans=0;int sign=0;int sum=0;int pos;
        for(int t=0;t<m;t++){
            cin>>str;int a=str[0]-‘A‘;int b=str[2]-‘A‘;
            if(!G[a][b]) {
                G[a][b]=1;in[b]++;
            }
            for(int i=0;i<n;i++)
                in1[i]=in[i];
            int sum=0;
            memset(vis,0,sizeof(vis));
            for(int i=0;i<n&&flag;i++){
                int sign1;bool k=false;
                for(int j=0;j<n;j++){
                   // cout<<j<<" "<<vis[j]<<" "<<in1[j]<<endl;
                    if(in1[j]==0&&!vis[j]){
                        sign1=j;sum++;k=true;
                    }
                }
              //  cout<<i<<" "<<k<<endl;
                vis[sign1]=1;
                if(!ans) topo[i]=sign1;
                if(!k){
                    flag=0;sign=t+1;
                }
                for(int j=0;j<n;j++){
                    if(!vis[j]) if(G[sign1][j]) in1[j]--;
                }
                pos=i;
            }
            if(pos==n-1&&sum==n&&!ans){
                ans=t+1;
            }

        }
        if(ans){
            printf("Sorted sequence determined after %d relations: ",ans);
            for(int i=0;i<n;i++){
                char c=topo[i]+‘A‘;
                cout<<c;
            }
            cout<<‘.‘<<endl;
        }
        else{
            if(sign){
                printf("Inconsistency found after %d relations.\n",sign);
            }
            else
                printf("Sorted sequence cannot be determined.\n");
        }
    }
    return 0;
}

  

POJ1094拓扑排序,布布扣,bubuko.com

POJ1094拓扑排序

原文:http://www.cnblogs.com/yigexigua/p/3845085.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!