本文簡要介紹ruby語言中 TSort.tsort
的用法。
用法
tsort()
返回拓撲排序的節點數組。數組從子節點到父節點排序,即第一個元素沒有子節點,最後一個節點沒有父節點。
如果存在循環,則會引發 TSort::Cyclic
。
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.tsort #=> [4, 2, 3, 1]
graph = G.new({1=>[2], 2=>[3, 4], 3=>[2], 4=>[]})
p graph.tsort # raises TSort::Cyclic
相關用法
- Ruby TSort.tsort用法及代碼示例
- Ruby TSort.tsort_each用法及代碼示例
- Ruby TSort.strongly_connected_components用法及代碼示例
- Ruby TSort.each_strongly_connected_component用法及代碼示例
- Ruby TSort.each_strongly_connected_component_from用法及代碼示例
- 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-lang.org大神的英文原創作品 TSort.tsort。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。