Это реализация Сито Эратосфена .
class PrimeGenerator
def self.get_primes_between( x, y)
sieve_array = Array.new(y) {|index|
(index == 0 ? 0 : index+1)
}
position_when_we_can_stop_checking = Math.sqrt(y).to_i
(2..position_when_we_can_stop_checking).each{|factor|
sieve_array[(factor).. (y-1)].each{|number|
sieve_array[number-1] = 0 if isMultipleOf(number, factor)
}
}
sieve_array.select{|element|
( (element != 0) && ( (x..y).include? element) )
}
end
def self.isMultipleOf(x, y)
return (x % y) == 0
end
end
Теперь я сделал это для «отправки решения проблем, поскольку у вас есть время убить». Я выбрал ruby в качестве моего языка impl .. однако я был объявлен тайм-аут.
Я сделал несколько тестов
require 'benchmark'
Benchmark.bmbm do |x|
x.report ("get primes") { PrimeGenerator.get_primes_between(10000, 100000)}
end
ruby 1.9.1p0 (версия 2009-01-30 21907) [i386-mswin32]
L:\Gishu\Ruby>ruby prime_generator.rb
Rehearsal ----------------------------------------------
get primes 33.953000 0.047000 34.000000 ( 34.343750)
------------------------------------ total: 34.000000sec
user system total real
get primes 33.735000 0.000000 33.735000 ( 33.843750)
ruby 1.8.6 (2007-03-13 уровень исправления 0) [i386-mswin32]
Rehearsal ----------------------------------------------
get primes 65.922000 0.000000 65.922000 ( 66.110000)
------------------------------------ total: 65.922000sec
user system total real
get primes 67.359000 0.016000 67.375000 ( 67.656000)
Так что я переделал это в C # 2.0 / VS 2008 ->
722 миллисекунд
Так что теперь это заставляет меня задуматься, не является ли это проблемой с моей реализацией, или же разница между языками настолько широка? (Я был поражен 1.9 Ruby VM ... пока мне не пришлось сравнивать его с C #:)
UPDATE:
В конце концов, это оказалось моей «адаптацией к позору и позору» :) Устранение ненужных итераций цикла было главной оптимизацией. В случае, если кто-то заинтересован в деталях .. вы можете прочитать это здесь ; в любом случае, этот вопрос слишком длинный.