Sha256: 4c0910712b4740e4637d75a2c9000ddc6873b69b2da43ca4d5078215184d2dde

Contents?: true

Size: 665 Bytes

Versions: 168

Compression:

Stored size: 665 Bytes

Contents

object Luhn {

  def valid(numberStr: String): Boolean = {
    val s = numberStr.replace(" ", "")

    s.length > 1 &&
      s.forall(c => c.isDigit) &&
      checksum(s.map(_.asDigit).toList) == 0
  }

  private def checkDigit(number: Long): Int = (number % 10).toInt

  private def addends(digits: List[Int]): List[Int] = {
    val zippedDigits = digits.reverse.zipWithIndex

    zippedDigits.map{case (m, i) => if (isOdd(i)) dbl(m) else m}
  }

  private def checksum(digits: List[Int]): Int = addends(digits).sum % 10

  private def dbl(n: Int) = {
    val dbled = n * 2

    if (dbled < 10) dbled else dbled - 9
  }

  private def isOdd(i: Int) = i % 2 == 1
}

Version data entries

168 entries across 168 versions & 1 rubygems

Version Path
trackler-2.2.1.139 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.138 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.137 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.136 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.135 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.134 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.133 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.132 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.131 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.130 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.129 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.128 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.127 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.126 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.125 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.124 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.123 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.122 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.121 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.120 tracks/scala/exercises/luhn/example.scala