programming-examples/ruby/Algorithms/count_primes.rb

14 lines
334 B
Ruby
Raw Normal View History

2019-11-15 12:59:38 +01:00
# Count the number of prime numbers less than a non-negative number, n.
#
# @param {Integer} number
# @return {Integer}
def count_primes(n)
primes = [nil, nil, *2..n]
(0..Math.sqrt(n)).each do |i|
(i**2..n).step(i) { |composite_number| primes[composite_number] = nil } unless primes[i].nil?
end
primes.compact.count
end