File: sieve.ruby

package info (click to toggle)
jruby 9.4.8.0%2Bds-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 89,244 kB
  • sloc: ruby: 548,574; java: 276,189; yacc: 25,873; ansic: 6,178; xml: 6,111; sh: 1,855; sed: 94; makefile: 78; jsp: 48; tcl: 40; exp: 12
file content (30 lines) | stat: -rw-r--r-- 588 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#!/usr/bin/ruby
# -*- mode: ruby -*-
# $Id: sieve.ruby,v 1.4 2004-11-10 06:48:59 bfulgham Exp $
# http://shootout.alioth.debian.org/
#
# Revised implementation by Paul Sanchez

NUM = Integer(ARGV.shift || 1)

max, flags = 8192, nil
flags0 = Array.new(max+1)
for i in 2 .. max
  flags0[i] = i
end

i=j=0

NUM.times do
    flags = flags0.dup
    #for i in 2 .. Math.sqrt(max)	#<-- This is much faster
    for i in 2 .. 8192 
	next unless flags[i]
	# remove all multiples of prime: i
	(i+i).step(max, i) do |j|
	    flags[j] = nil
	end
    end
end

print "Count: ", flags.compact.size, "\n"