htc 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas
..
LICENSE 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas
README.md 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas
index.d.ts 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas
index.js 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas
index.js.flow 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas
package.json 7ca38fdcbb 善行少年PC端首次提交(基础版) hace 2 semanas

README.md

@rtsao/scc

Find strongly connected components of a directed graph using Tarjan's algorithm.

This algorithm efficiently yields both a topological order and list of any cycles.

Installation

yarn add @rtsao/scc
npm install @rtsao/scc

Usage

const scc = require("@rtsao/scc");

const digraph = new Map([
  ["a", new Set(["c", "d"])],
  ["b", new Set(["a"])],
  ["c", new Set(["b"])],
  ["d", new Set(["e"])],
  ["e", new Set()]
]);

const components = scc(digraph);
// [ Set { 'e' }, Set { 'd' }, Set { 'b', 'c', 'a' } ]

Illustration of example input digraph

┌───┐     ┌───┐
│ d │ ◀── │ a │ ◀┐
└───┘     └───┘  │
  │         │    │
  ▼         ▼    │
┌───┐     ┌───┐  │
│ e │     │ c │  │
└───┘     └───┘  │
            │    │
            ▼    │
          ┌───┐  │
          │ b │ ─┘
          └───┘