Sha256: 954e3895631c17cdaed0e158d16132adaa73eebab90f0a0176f05c926d95841d
Contents?: true
Size: 1.04 KB
Versions: 7
Compression:
Stored size: 1.04 KB
Contents
module Enumerable # Returns an array of elements for the elements that occur n times. # Or according to the results of a given block. # # [1,1,2,3,3,4,5,5].occur(1) #=> [2,4] # [1,1,2,3,3,4,5,5].occur(2) #=> [1,3,5] # [1,1,2,3,3,4,5,5].occur(3) #=> [] # # [1,2,2,3,3,3].occur(1..1) #=> [1] # [1,2,2,3,3,3].occur(2..3) #=> [2,3] # # [1,1,2,3,3,4,5,5].occur { |n| n == 1 } #=> [2,4] # [1,1,2,3,3,4,5,5].occur { |n| n > 1 } #=> [1,3,5] # # CREDIT: ? def occur(n=nil) #:yield: result = Hash.new { |hash, key| hash[key] = Array.new } self.each do |item| key = item result[key] << item end if block_given? result.reject! { |key, values| ! yield(values.size) } else raise ArgumentError unless n if Range === n result.reject! { |key, values| ! n.include?(values.size) } else result.reject! { |key, values| values.size != n } end end return result.values.flatten.uniq end end
Version data entries
7 entries across 7 versions & 2 rubygems