summaryrefslogtreecommitdiff
path: root/test/pending/shootout/sieve.scala
blob: b494980ee431499049ac9e401360cef8a0ec0833 (plain) (blame)
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
31
32
33
34
35
36
37
38
39
40
41
42
43
/* The Computer Language Shootout 
   http://shootout.alioth.debian.org/
   contributed by Isaac Gouy (Scala novice)
*/

object sieve {
   def main(args: Array[String]) = {
      var n = toPositiveInt(args);
      val start = 2;
      val stop = 8192;
      val isPrime = new Array[Boolean](stop+1);
      var count: Int = 0;

      while (n>0) { 
         count = 0;

         for (i <- Iterator.range(start,stop+1)) 
            isPrime(i)=true;

         for (i <- Iterator.range(start,stop+1)) {
            if( isPrime(i) ) {
               var k = i+i;
               while (k<=stop) { isPrime(k)=false; k=k+i; }
               count = count+1;
            }
         }
         n=n-1; 
      }

      Console.println("Count: " + count);
   }


   private def toPositiveInt(s: Array[String]) = {
      val i = 
         try { Integer.parseInt(s(0)); } 
         catch { case _ => 1 }
      if (i>0) i; else 1;
   }
}