Ruby注入奇怪的行为

时间:2015-03-02 23:23:14

标签: ruby arrays functional-programming inject

我正在尝试生成给定数组的完整排列。例如,如果输入为fact(2, ['A', 'B']),则输出应为[["A", "A"], ["B", "A"], ["A", "B"], ["B", "B"]]

def fact(n, arr)
    return [[]] if n == 0
    nxt = fact(n - 1, arr).freeze
    arr.inject([]){ |result, elem| nxt.each { |x| result.push(x + [elem]); result } }
end

然而,当我尝试使用“更多功能编程”方式进行此操作时,发生了一些奇怪的事情。口译员抱怨Untitled 4.rb:4:in 'push': can't modify frozen Array (RuntimeError)。我实际上是在尝试修改名为result的注入数组,它怎么能改变nxt

2 个答案:

答案 0 :(得分:3)

它是内置的,它是懒惰的:

perms = ['A', 'B'].repeated_permutation(2)
#use the resulting enumerator like this:
perms.each{|perm| p perm}

答案 1 :(得分:1)

结果是一个错字。

def fact(n, arr)
    return [[]] if n == 0
    nxt = fact(n - 1, arr).freeze
    arr.inject([]){ |a, elem| nxt.each { |x| a.push(x + [elem]) }; a }
end