Sha256: 177f3565abd683f78c16eac230e0b2e91e7d08a78234396739f016086103a3fd

Contents?: true

Size: 1.32 KB

Versions: 1

Compression:

Stored size: 1.32 KB

Contents

#
# Ronin - A Ruby platform for exploit development and security research.
#
# Copyright (c) 2006-2009 Hal Brodigan (postmodern.mod3 at gmail.com)
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
#

class Array

  #
  # Calculates the power-set of the Array.
  #
  # @return [Array]
  #   The power set of the array.
  #
  # @example
  #   [1,2,3].power_set
  #   # => [[], [3], [2], [2, 3], [1], [1, 3], [1, 2], [1, 2, 3]]
  #
  # @see http://johncarrino.net/blog/2006/08/11/powerset-in-ruby/
  #
  def power_set
    inject([[]]) do |power_set,element|
      sub_set = []

      power_set.each do |i|
        sub_set << i
        sub_set << i + [element]
      end

      sub_set
    end
  end

end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
ronin-0.3.0 lib/ronin/extensions/array.rb