當前位置: 首頁>>編程示例 >>用法及示例精選 >>正文


Ruby TSort.strongly_connected_components用法及代碼示例

本文簡要介紹ruby語言中 TSort.strongly_connected_components 的用法。

用法

strongly_connected_components()

以節點數組的形式返回強連通分量。該數組從子級到父級排序。數組的每個元素代表一個強連通分量。

class G
  include TSort
  def initialize(g)
    @g = g
  end
  def tsort_each_child(n, &b) @g[n].each(&b) end
  def tsort_each_node(&b) @g.each_key(&b) end
end

graph = G.new({1=>[2, 3], 2=>[4], 3=>[2, 4], 4=>[]})
p graph.strongly_connected_components #=> [[4], [2], [3], [1]]

graph = G.new({1=>[2], 2=>[3, 4], 3=>[2], 4=>[]})
p graph.strongly_connected_components #=> [[4], [2, 3], [1]]

相關用法


注:本文由純淨天空篩選整理自ruby-lang.org大神的英文原創作品 TSort.strongly_connected_components。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。