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


Ruby TSort.tsort用法及代碼示例

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

用法

tsort(each_node, each_child)

返回拓撲排序的節點數組。數組從子節點到父節點排序,即第一個元素沒有子節點,最後一個節點沒有父節點。

該圖由 each_nodeeach_child 表示。 each_node 應該有 call 方法,該方法為圖中的每個節點生成。 each_child 應該有 call 方法,它接受一個節點參數並為每個子節點產生。

如果存在循環,則會引發 TSort::Cyclic

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.tsort(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.tsort(each_node, each_child) # raises TSort::Cyclic

相關用法


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