• 拓扑排序的实现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;

    }

  • 相关阅读:
    【转】数据库中查询记录时是否每次只能使用一个索引?
    【转】MySQL理解索引、添加索引的原则
    【转】.htaccess详解及.htaccess参数说明
    【转】BASE64编码简介
    【转】联想笔记本进入u盘启动项操作方法详解
    【转】UEFI是什么?与BIOS的区别在哪里?UEFI详解!
    55. Jump Game
    54. Spiral Matrix
    53. Maximum Subarray
    52. N-Queens II
  • 原文地址:https://www.cnblogs.com/zhanglanyun/p/2477945.html
Copyright © 2020-2023  润新知