zoukankan      html  css  js  c++  java
  • 拓扑排序的实现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;

    }

  • 相关阅读:
    Server2012R2 ADFS3.0 The same client browser session has made '6' requests in the last '13'seconds
    pig的grunt中shell命令不稳定,能不用尽量不用
    pig脚本的参数传入,多个参数传入
    pig的cogroup详解
    pig的limit无效(返回所有记录)sample有效
    Dynamics CRM2013 任务列表添加自定义按钮
    简述浏览器渲染机制
    如何区分浏览器类型
    使用mock.js生成前端测试数据
    理解Ajax
  • 原文地址:https://www.cnblogs.com/zhanglanyun/p/2477945.html
Copyright © 2011-2022 走看看