Sha256: 1d418cad19b5b3afb19102597e9d21b6f73f96b00de8e0e800a8306d93ab3dd3

Contents?: true

Size: 502 Bytes

Versions: 151

Compression:

Stored size: 502 Bytes

Contents

open Core

let every_second_digit_doubled =
  let double_digit n = let d = n * 2 in if d >= 10 then d - 9 else d in
  List.rev_mapi ~f:(fun i -> if i % 2 = 1 then double_digit else Fn.id)

let valid s =
  let s = String.filter s ~f:(fun ch -> ch <> ' ') in
  if String.length s > 1
  then
    let checksum = String.to_list s
    |> List.rev_map ~f:(fun ch -> Char.to_int ch - Char.to_int '0')
    |> every_second_digit_doubled
    |> List.sum (module Int) ~f:Fn.id in
    checksum % 10 = 0
  else false

Version data entries

151 entries across 151 versions & 1 rubygems

Version Path
trackler-2.2.1.90 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.89 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.88 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.87 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.86 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.85 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.84 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.83 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.82 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.81 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.80 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.79 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.78 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.77 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.76 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.75 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.74 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.73 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.72 tracks/ocaml/exercises/luhn/example.ml
trackler-2.2.1.71 tracks/ocaml/exercises/luhn/example.ml