Sha256: b73e89023c903e41305d534027ae9b40dab98ec2142bd66d6a924e0e6d16a9e5

Contents?: true

Size: 813 Bytes

Versions: 26

Compression:

Stored size: 813 Bytes

Contents

unless Array.method_defined? :permutation
  require 'backports/tools'
  require 'enumerator'

  class Array
    def permutation(num = Backports::Undefined)
      return to_enum(:permutation, num) unless block_given?
      num = num.equal?(Backports::Undefined) ?
            size :
            Backports.coerce_to_int(num)
      return self unless (0..size).include? num

      final_lambda = lambda do |partial, remain|
        yield partial
      end

      outer_lambda = (1..num).inject(final_lambda) do |proc, _|
        lambda do |partial, remain|
          remain.each_with_index do |val, i|
            new_remain = remain.dup
            new_remain.delete_at(i)
            proc.call(partial.dup << val, new_remain)
          end
        end
      end

      outer_lambda.call([], dup)
    end
  end
end

Version data entries

26 entries across 26 versions & 2 rubygems

Version Path
scout_realtime-1.0.5 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-1.0.4 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-1.0.3 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-1.0.3.pre lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-1.0.2 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-1.0.1 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-1.0.0 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-0.5.5 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-0.5.5.pre lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-0.5.4 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
backports-3.6.0 lib/backports/1.8.7/array/permutation.rb
backports-3.5.0 lib/backports/1.8.7/array/permutation.rb
backports-3.4.1 lib/backports/1.8.7/array/permutation.rb
scout_realtime-0.5.3 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-0.5.2 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
scout_realtime-0.5.1 lib/vendor/backports-3.3.5/lib/backports/1.8.7/array/permutation.rb
backports-3.4.0 lib/backports/1.8.7/array/permutation.rb
backports-3.3.5 lib/backports/1.8.7/array/permutation.rb
backports-3.3.4 lib/backports/1.8.7/array/permutation.rb
backports-3.3.3 lib/backports/1.8.7/array/permutation.rb