当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Ruby TSort.each_strongly_connected_component_from用法及代码示例


本文简要介绍ruby语言中 TSort.each_strongly_connected_component_from 的用法。

用法

each_strongly_connected_component_from(node, each_child, id_map={}, stack=[]) { |nodes| ... }

迭代图中的强连通分量。该图由 nodeeach_child 表示。

node 是第一个节点。 each_child 应该有 call 方法,它接受一个节点参数并为每个子节点产生。

返回值未指定。

TSort.each_strongly_connected_component_from 是一个类方法,它不需要一个类来表示包含 TSort 的图。

graph = {1=>[2], 2=>[3, 4], 3=>[2], 4=>[]}
each_child = lambda {|n, &b| graph[n].each(&b) }
TSort.each_strongly_connected_component_from(1, each_child) {|scc|
  p scc
}
#=> [4]
#   [2, 3]
#   [1]

相关用法


注:本文由纯净天空筛选整理自ruby-lang.org大神的英文原创作品 TSort.each_strongly_connected_component_from。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。