Skip to content

Instantly share code, notes, and snippets.

@daniellandau
Created March 15, 2014 20:40
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save daniellandau/9573650 to your computer and use it in GitHub Desktop.
Save daniellandau/9573650 to your computer and use it in GitHub Desktop.
Reaktor Fast Track
import scala.util.parsing.combinator._
import scala.io.Source
class OutRunParser extends JavaTokenParsers {
override val skipWhitespace = false
def int: Parser[Int] = wholeNumber ^^ (_.toInt)
def ints: Parser[List[Int]] = repsep(int, """[ \t]+""".r)
def tree: Parser[List[List[Int]]] = repsep(ints, """\n""".r)
}
object OutRunCalculator extends OutRunParser {
def joinLines( acc: List[Int], x: List[Int] ) : List[Int] = {
if (x.length + 1 != acc.length) {
throw new IllegalArgumentException("Puun tulisi kasvaa yhdellä luvulla joka rivillä")
}
var newAcc : List[Int] = Nil
for (i <- 0 until x.length) {
newAcc = x(i) + math.max(acc(i), acc(i+1)) :: newAcc
}
return newAcc.reverse
}
def main(args: Array[String]) {
if (args.length != 1) {
throw new IllegalArgumentException("Anna tiedoston nimi tai URL argumenttina")
}
var source: Source = null
if (args(0).startsWith("http")) {
source = Source.fromURL(args(0))
} else {
source = Source.fromFile(args(0))
}
val lines = source.getLines.toList
println(lines.head)
val treeLines = lines.tail.mkString("\n")
val result = parseAll(tree, treeLines)
result match {
case Success(tree, _) => {
val reversed = tree.reverse
val res = reversed.tail.foldLeft[List[Int]]( reversed.head)( joinLines).head
println(s"$res tykkäystä")
}
case _ => throw new IllegalArgumentException("Puu ei ollut oikein muodostettu")
}
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment