Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > tsortライブラリ > TSortモジュール > strongly_connected_components
strongly_connected_components(each_node, each_child) -> Array
[permalink][rdoc]強連結成分の集まりを配列の配列として返します。 この配列は子から親に向かってソートされています。 各要素は強連結成分を表す配列です。
引数 each_node と each_child でグラフを表します。
使用例
g = {1=>[2, 3], 2=>[4], 3=>[2, 4], 4=>[]} each_node = lambda {|&b| g.each_key(&b) } each_child = lambda {|n, &b| g[n].each(&b) } p TSort.strongly_connected_components(each_node, each_child) # => [[4], [2], [3], [1]] g = {1=>[2], 2=>[3, 4], 3=>[2], 4=>[]} each_node = lambda {|&b| g.each_key(&b) } each_child = lambda {|n, &b| g[n].each(&b) } p TSort.strongly_connected_components(each_node, each_child) # => [[4], [2, 3], [1]]
[SEE_ALSO] TSort#strongly_connected_components