tarjan

package
v0.34.1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Oct 12, 2023 License: BSD-3-Clause Imports: 0 Imported by: 0

Documentation

Overview

package tarjan implements a graph loop detection algorithm called Tarjan's algorithm.

The algorithm takes a input graph and produces a slice where each item is a slice of strongly connected vertices. The input graph is in form of a map where the key is a graph vertex and the value is the edges in for of a slice of vertices.

Algorithm description: http://en.wikipedia.org/wiki/Tarjan’s_strongly_connected_components_algorithm

Based on an implementation by Gustavo Niemeyer (in mgo/txn): http://bazaar.launchpad.net/+branch/mgo/v2/view/head:/txn/tarjan.go

Index

Examples

Constants

This section is empty.

Variables

This section is empty.

Functions

func Connections

func Connections(graph map[interface{}][]interface{}) [][]interface{}

Connections creates a slice where each item is a slice of strongly connected vertices.

If a slice item contains only one vertex there are no loops. A loop on the vertex itself is also a connected group.

The example shows the same graph as in the Wikipedia article.

Example
graph := make(map[interface{}][]interface{})
graph["1"] = []interface{}{"2"}
graph["2"] = []interface{}{"3"}
graph["3"] = []interface{}{"1"}
graph["4"] = []interface{}{"2", "3", "5"}
graph["5"] = []interface{}{"4", "6"}
graph["6"] = []interface{}{"3", "7"}
graph["7"] = []interface{}{"6"}
graph["8"] = []interface{}{"5", "7", "8"}

o := Connections(graph)
output := sortConnections(o)
fmt.Println(output)
Output:

[[1 2 3] [6 7] [4 5] [8]]

Types

This section is empty.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL