美文网首页
有向图(二)

有向图(二)

作者: sleepyjoker | 来源:发表于2016-09-28 18:39 被阅读86次

拓扑排序:

public class Topological{
    private Iterable<Integer> order;        //顶点的拓扑排序
    public Topological(Digraph G){
        DirectedCycle cyclefinder = new DirectedCycle(G);
        if(!cyclefinder.hasCycle()){
            DepthFirstOrder dfs = new DepthFirstOrder(G);
            order = dfs.reversePost();
        }
    }
    public Iterable<Integer> order(){
        return order;
    }
    public boolean isDAG(){
        return order != null;
    }
    public static void main(String[] args){
        String filename = args[0];
        String separator = args[1];
        SymbolDigraph sg = new SymbolDigraph(filename, separator);
        Topological top = new Topological(sg.G());
        for( int v: top.order())
            StdOut.println(sg.name(v));
    }
}

一幅有向图的拓扑排序即为所有顶点的逆后序排列。
证明: 对于任意边v->w,在调用dfs(v)时,只会是以下两种情况:
1.dfs(w)已经被调用过且已经返回了(w已经被标记)。
2.dfs(w)还没有被调用(w还未被标记),因此v->w会直接或间接调用并返回dfs(w),且dfs(w)会在dfs(v)返回之前返回。
在两种可能的情况中,dfs(w)都会在dfs(v)之前完成,因此在后序排列中w排在v之前而在逆后序排列中w排在v之后。因此任意一条边的v->w都如我们所愿地从排名较前的点指向排名较后的点。

有向图中的强连通性

如果两个顶点v和w是相互可达的,则称它们为强连通的。

强连通分量的API

public class SCC
             SCC(Digraph G)              //预处理构造函数
     boolean strongConnected(int v, int w)     //判断v和w是否连通
         int count()              //图中强连通分量总数
         int id(int v)              //v所在的强连通分量的标识符

计算无向图中的连通分量只是深度优先搜索的一个简单应用。Kosaraju算法简单的修改之前的算法即可实现新的功能。

public class KosarajuSCC{
    private boolean[] marked;          //已访问过的顶点
    private int[] id;                //强连通分量的标识符
    private int count;            //强连通分量的数量

    public KosarajuSCC(Digraph G){
        marked = new boolean[G.V()];
        id = new int[G.V()];
        DepthFirstOrder order = new DepthFirstOrder(G.reverse());
        for( int s: order.reversePost())
            if(!marked[s])
            {    dfs(G, s);  count++;  }
    }
    private void dfs(Digraph G, int v){
        marked[v] = true;
        id[v] = count;
        for(int w:G.adj(v))
            if( !marked[s])
                dfs(G, w);
    }
    public boolean stronglyConnected(int v, int w){
        return id[v] == id[w];
    }
    public int id(int v){
        return id[v];
    }
    public int count(){
        return count;
    }
}

先使用深度优先搜索查找给定的有向图G的反向图,根据由此得到的所有顶点的逆后序再次深度优先处理有向图(Kosaraju算法),其构造函数中的每一次递归调用所标记的顶点都在同一个强连通分量中。


顶点对的可达性
对于“是否存在一条从一个给定的顶点v到另一个给定的顶点w的路径”等类似的问题,在有向图中需要线性级别的预处理时间才能支持常数时间的查询操作。

有向图的传递闭包是由相同的一组顶点组成的另一幅有向图,在传递闭包中存在一条从v指向w的边当且仅当在G中w是从v可达的。

根据约定,每个顶点对于自己都是可达的,因此传递闭包会含有V个自环。一般而言,一幅有向图传递闭包所含的边都比原图多得多,一幅稀疏图的传递闭包确实一幅稠密图也是很常见的,例如含有v个顶点和v条边的有向环的传递闭包是一幅v²条边的有向完全图。因为传递闭包一般都很稠密,我们通常将它们表示为一个布尔值矩阵,其中v行w列的值为true当且仅当w是从v可达的。与其计算一幅有向图的传递闭包,比如使用深度优先搜索算法来实现以下API:

public class TransitiveClosure
             TransitiveClosure(Digraph G)         // 预处理的构造函数
     boolean reachable(int v, int w)              //判断w是否可从v到达

下面是实现的代码,无论对于稀疏还是稠密的图,它都是理想的解决方案。但它不适用于在实际应用中遇到的大型有向图,因为构造函数所需的空间和v²成正比,所需的时间和v(v+e)成正比。

public class TransitiveClosure{
    private DirectedDFS[] all;
    TransitiveClosure(Digraph G){
        all = new DirectedDFS[G.V()];
        for( int v = 0; v< G.V(); v++)
            all[v] = new DirectedDFS(G, v);
    }
    boolean reachable(int v, int w){
        return all[v].marked(w);
    }
}

相关文章

  • 有向图(二)

    拓扑排序: 一幅有向图的拓扑排序即为所有顶点的逆后序排列。证明: 对于任意边v->w,在调用dfs(v)时,只会是...

  • 数据结构_图(2_图的存储结构)

    二、图的存储结构 2.1 邻接矩阵 2.1.1无向图 2.1.2有向图 2.1.3无向网 2.1.4有向网 2.2...

  • 数据结构-学习二

    图: 无向图,有向图度,子图,路径,环,连通图,连通子图。 存储: 邻接矩阵二维数组。 邻接表+数组加链表优先搜...

  • 图论——深度优先遍历和广度优先遍历(Java)

    图数据结构的定义 无向图 无向图的特点 邻接矩阵是对称的 有向图 图的存储 邻接矩阵存储方式 如下图所示,二维矩阵...

  • 有向图和最短路径Dijkstra、Bellman-Ford、Fl

    本篇开始讨论关于有向图的算法,无向图是特殊的有向图。内容概要: 有向图的实现 最短路径经典算法实现 有向图的实现 ...

  • 几个概念:有向图、无向图、加权图、简单图、联通、联通分量、生成树、强连通分量、强联通图图的存储:邻接矩阵(二维、一...

  • 任务调度-DAG和Oozie基础

    本文主要内容 有向无环图 拓扑排序 Oozie 有向无环图 什么是有向无环图 有向无环图(Directed Acy...

  • 《算法》-图[有向图]

    有向图 简单的来说有向图就是连接带方向的图。有向图的例子在现实生活中也很多,比如在一段时间内银行间的现金流动,或者...

  • 数据结构-图

    数据结构 - 图 目录: 基本概念无向图有向图 储存结构邻接矩阵邻接表十字链表(有向图)邻接多重表(无向图) 图的...

  • 图的表示

    图的概念 无向图无向图 有向图有向图 带权图带权图 顶点:图中的元素。 边:图中的一个顶点可以与任意其他顶点建立连...

网友评论

      本文标题:有向图(二)

      本文链接:https://www.haomeiwen.com/subject/xrlhyttx.html