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.119 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.118 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.117 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.116 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.115 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.114 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.113 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.111 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.110 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.109 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.108 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.107 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.106 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.105 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.104 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.103 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.102 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.101 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.100 tracks/scala/exercises/luhn/example.scala
trackler-2.2.1.99 tracks/scala/exercises/luhn/example.scala