Sha256: a99a0ba59aa4153a7829a2104307566533f64f46d49a565570acf267a6ba3021

Contents?: true

Size: 675 Bytes

Versions: 396

Compression:

Stored size: 675 Bytes

Contents

import scala.annotation.tailrec

object Grains {
  type Grains = BigInt
  type ChessboardSquare = Int

  private val ChessboardSquares = 64

  def square(cbSquare: ChessboardSquare): Option[Grains] = {
    def isValidChessboardSquare(n: Int) =
      1 <= n && n <= ChessboardSquares

    def powerOfTwo(n: Int): BigInt = {
      @tailrec
      def loop(n: Int, acc: BigInt): BigInt =
        if (n == 0) acc
        else loop(n - 1, acc * 2)

      loop(n, 1)
    }

    val pred = (_:Int) - 1

    Option(cbSquare) filter isValidChessboardSquare map pred.andThen(powerOfTwo)
  }

  def total: Grains =
    (1 to ChessboardSquares) flatMap (square _).andThen(_.toList) sum
}

Version data entries

396 entries across 396 versions & 1 rubygems

Version Path
trackler-2.0.0.5 tracks/scala/exercises/grains/example.scala
trackler-2.0.0.4 tracks/scala/exercises/grains/example.scala
trackler-2.0.0.3 tracks/scala/exercises/grains/example.scala
trackler-2.0.0.2 tracks/scala/exercises/grains/example.scala
trackler-2.0.0.1 tracks/scala/exercises/grains/example.scala
trackler-2.0.0.0 tracks/scala/exercises/grains/example.scala
trackler-1.0.4.1 tracks/scala/exercises/grains/example.scala
trackler-1.0.4.0 tracks/scala/exercises/grains/example.scala
trackler-1.0.3.0 tracks/scala/exercises/grains/example.scala
trackler-1.0.2.1 tracks/scala/exercises/grains/example.scala
trackler-1.0.2.0 tracks/scala/exercises/grains/example.scala
trackler-1.0.1.2 tracks/scala/exercises/grains/example.scala
trackler-1.0.1.1 tracks/scala/exercises/grains/example.scala
trackler-1.0.1.0 tracks/scala/exercises/grains/example.scala
trackler-1.0.0.1 tracks/scala/exercises/grains/example.scala
trackler-1.0.0 tracks/scala/exercises/grains/example.scala