全组合的递归实现(ruby)

Posted Liz-

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了全组合的递归实现(ruby)相关的知识,希望对你有一定的参考价值。

着急用所以直接扒了一个C++算法翻译成了ruby…暂记

 1 nodes = ["node1", "node2", "node3", "node4", "node5", "node6"]
 2 
 3 def combine_array(arr, start, index, count, num ,len, output)         
 4     for i in (start..len-1)
 5       index[count-1] = i
 6       if count-1 == 0 then
 7         out = []
 8         for j in (0..num-1)       
 9         out << arr[index[j]]                     
10         end
11         #puts "#{out}"
12         #puts "------------"
13         output << out
14       else
15         combine_array(arr, i+1, index, count-1, num, len, output)
16       end
17    end
18 end
19 
20 for i in (1..6)
21   outs = []
22   combine_array(nodes, 0, index, i, i, len, outs)
23   p outs
24   puts "------------"
25 end

 

以上是关于全组合的递归实现(ruby)的主要内容,如果未能解决你的问题,请参考以下文章

递归基础_全排列(一般递推实现)

算法之使用递归求解全排列

算法学习——递归和排列组合

93. 递归实现组合型枚举

[Leetcode 46]全排列 Permutations 递归

JavaScript 代码片段