Javascript图算法

现实世界中很多事物都是以网络形式组织的,例如人们的社交网络,道路交通网络等。社交媒体的发达使网络的研究更加火热。
网络在计算机中以图graph来表示,具体的表示方法将很大程度上决定图的各类算法的效率。
图由边edge和顶点vertex组成,一条边连接两个顶点,根据边是否有方向可以将图分为无向图和有向图。
图中的一条路径path经过多个顶点,路径中可以重复经过一个顶点两次或以上,称为环路loop。
图中两个顶点存在路径称为连通。一个图是强练通(strongly connected),如果它的任意两个顶点都连通。


顶点的js定义

function Vertex(label) {
   this.label = label;
}

构造一个Graph
function Graph(v) {
    this.vertices = v;
    this.edges = 0;
    this.adj = []; 
    // 访问标记
    this.marked = [];
    for (var i = 0; i < this.vertices; ++i)  {
        this.adj[i] = [ ];
        this.adj[i].push("");
        this.marked[i] = false;
    }
    this.addEdge = addEdge;
    this.toString = toString;
}

function addEdge(v, w) {
    this.adj[v].push(w);
    this.adj[w].push(v);
    this.edges++;
}

function show() {
    for (var i = 0; i< this.vertices; i++) {
        print(i+" -> ");
        for (var j = 0; j < this.adj[i].length; ++j) {
            print(this.adj[i][j]);
        }
    }
}

function dfs(v) {
    this.marked[v] = true;
    print("Visit vertex: " + v);
    for each (var w in this.adj[v]) {
        if (!this.marked[w]) {
            this.dfs(w);
        }
    }
}

function bfs(v) {
    var queue = [];
    queue.push(v);
    while (queue.length > 0) {
        var s = queue.shift();
        print("Visit vertex: " + s);
        this.marked[s] = true;
        for each (var w in this.adj[s]) {
            if (!this.marked[w]) {
                queue.push(w);
            }    
        }
    }
}

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • https://zh.visualgo.net/graphds 浅谈图形结构https://zh.visualgo...
    狼之独步阅读 4,241评论 0 0
  • 图是一种比线性表和树更复杂的数据结构,在图中,结点之间的关系是任意的,任意两个数据元素之间都可能相关。图是一种多对...
    Alent阅读 2,347评论 1 22
  • 第一章 绪论 什么是数据结构? 数据结构的定义:数据结构是相互之间存在一种或多种特定关系的数据元素的集合。 第二章...
    SeanCheney阅读 5,822评论 0 19
  • 一些概念 数据结构就是研究数据的逻辑结构和物理结构以及它们之间相互关系,并对这种结构定义相应的运算,而且确保经过这...
    Winterfell_Z阅读 5,994评论 0 13
  • 一、错题背后的原因 这几天在研究今年的省考中考卷,有些题目错得很令人匪夷所思。于是我去初三,问今年考试的孩子们...
    sunflower80阅读 594评论 0 0