sieve.scala
来自「JAVA 语言的函数式编程扩展」· SCALA 代码 · 共 44 行
SCALA
44 行
/* 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 = _; while (n>0) { count = 0; for (val i <- Iterator.range(start,stop+1)) isPrime(i)=true; for (val 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; }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?