本文簡要介紹ruby語言中 TSort.each_strongly_connected_component_from
的用法。
用法
each_strongly_connected_component_from(node, each_child, id_map={}, stack=[]) { |nodes| ... }
迭代圖中的強連通分量。該圖由 node
和 each_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 TSort.each_strongly_connected_component用法及代碼示例
- Ruby TSort.tsort用法及代碼示例
- Ruby TSort.strongly_connected_components用法及代碼示例
- Ruby TSort.tsort_each用法及代碼示例
- Ruby TSort模塊用法及代碼示例
- Ruby Time tv_sec用法及代碼示例
- Ruby Time usec用法及代碼示例
- Ruby TCPServer.accept用法及代碼示例
- Ruby Time yday()用法及代碼示例
- Ruby Time succ()用法及代碼示例
- Ruby Time mon()用法及代碼示例
- Ruby Time.gmtime用法及代碼示例
- Ruby Time iso8601用法及代碼示例
- Ruby Time.at用法及代碼示例
- Ruby Thread.kill用法及代碼示例
- Ruby Time.utc_offset用法及代碼示例
- Ruby Time.isdst用法及代碼示例
- Ruby TracePoint.defined_class用法及代碼示例
- Ruby Time.time + numeric用法及代碼示例
- Ruby Thread.pending_interrupt?用法及代碼示例
- Ruby Time wednesday?用法及代碼示例
- Ruby Time.wednesday?用法及代碼示例
- Ruby Thread kill()用法及代碼示例
- Ruby Time asctime()用法及代碼示例
- Ruby TypeError類用法及代碼示例
注:本文由純淨天空篩選整理自ruby-lang.org大神的英文原創作品 TSort.each_strongly_connected_component_from。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。