拓扑排序的实现DFS

缺点:当图有环的时候,是准确的

原理:

f[u] , f[v] dag图上的任一结点u,v的完成时刻

若存在有向边<u,v> , f[v] < f[u]    : u----->v  f[v] < f[u]

 

所以按完成时刻倒序排列即可

 

 

#include<iostream>

using namespace std;

 

int timef = 0;

 

int n ;

int a[1000][1000];// 图的邻接矩阵

 

int f[1000];  //完成时间

 

int vis[1000];  //1代表 被发现 2代表 已完成

 

 

 

void DFS(int u)

{

       vis[u] = 1;   //记录发现时刻

 

       for(int v=1; v<=n; v++) //adj(u)   //O(E)

              if(a[u][v] && vis[v]==0)

               DFS(v);

 

       Vis[u] = 2;  //记录完成时刻

       timef++;

       f[u] = timef;

}

 

void DFS_main()   //O(V+E)

{

       timef = 0;

 

       for(int i=1; i<=n; i++)             /// O(V)

       {

              if(vis[i] == 0)

                     DFS(i);

       }

}

 

 

void Topological_sort()      //O(V+E)

{

       int tp[1000];            ////存放拓扑序列1..V

       DFS_main();

 

       for(int i=1; i<=n; i++)   //finish的时间倒序存放在tp序列tp

        tp[n-f[i]+1] = i;

      

       for(int i=1; i<=n; i++)

              cout<<tp[i]<<" ";

       cout<<endl;

}

 

 

 

int main()

{

       memset(vis,0,sizeof(vis));

       cin>>n;

       for(int i=1; i<=n; i++)

              for(int j=1; j<=n; j++)

                     cin>>a[i][j];

      

       Topological_sort();

 

 

       system("pause");

       return 0;

}

posted @ 2012-05-01 16:05  张兰云  阅读(846)  评论(0编辑  收藏  举报