Мария обнови решението на 15.10.2013 03:10 (преди над 11 години)
+require 'prime'
+
+class Integer
+ def prime?
+ 2.upto(Math.sqrt(abs)).each do |potential_divisor|
+ return false if self % potential_divisor == 0
+ end
+ true
+ end
+
+ def prime_factors
+ prime_factors = []
+ abs.prime_division.map { |factor, power| Array.new(power, factor) }.flatten
+ end
+
+ def harmonic
+ 1.upto(self).map { |n| Rational(1, n) }.inject { |a, b| a + b }
+ end
+
+ def digits
+ abs.to_s.split(//).map { |digit| digit.to_i }
+ end
+end
+
+class Array
+ def frequencies
+ frequencies = Hash.new(0)
+ each { |item| frequencies[item] += 1 }
+ return frequencies
+ end
+
+ def average
+ inject { |a, b| a + b }. to_f / size
+ end
+
+ def drop_every(n)
+ each_slice(n).map { |s| if s.size == n then s[0...-1] else s end }.flatten
+ end
+
+ def combine_with(array)
+ if array.size <= size
+ zip(array).flatten.compact
+ else
+ zip(array).flatten.compact + array.drop(size)
+ end
+ end
+end