|
Scala example source code file (sieve.scala)
The Scala sieve.scala source code
/* 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;
}
}
Other Scala examples (source code examples)Here is a short list of links related to this Scala sieve.scala source code file: |
| ... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.