Sha256: 3eb62d8617b85f3e6de9dd78335eb5214f612784e769ef4604f7c2976eba9f36

Contents?: true

Size: 1.33 KB

Versions: 151

Compression:

Stored size: 1.33 KB

Contents

open Core

let substitute = function
  | 'a' .. 'z' as c ->
    let offset = (Char.to_int c) - (Char.to_int 'a') in
    let code = (Char.to_int 'z') - offset in
    Char.of_int_exn code
  | other -> other

let is_encodable = function
  | 'a' .. 'z' | '0' .. '9' -> true
  | _ -> false

let explode s =
  let rec expl i l =
    if i < 0 then
      l
    else
      expl (i - 1) (s.[i] :: l)
  in
  expl ((String.length s) - 1) []

let implode l =
  let character_at i = List.nth_exn l i in
  String.init (List.length l) ~f:character_at

let rec group n l =
  if (List.length l) <= n then
    [l]
  else
    (List.take l n) :: (group n (List.drop l n))

let encode ?block_size:(block_size = 5) text =
  let lowercase_text = String.lowercase text in
  let characters = explode lowercase_text in
  let filtered_characters = List.filter ~f:is_encodable characters in
  let groups = group block_size filtered_characters in
  let preprocessed_texts = List.map ~f:implode groups in
  let texts = List.map ~f:(String.map ~f:substitute) preprocessed_texts in
  String.concat ~sep:" " texts

let decode text =
  let lowercase_text = String.lowercase text in
  let characters = explode lowercase_text in
  let filtered_characters = List.filter ~f:is_encodable characters in
  let preprocessed_text = implode filtered_characters in
  String.map ~f:substitute preprocessed_text

Version data entries

151 entries across 151 versions & 1 rubygems

Version Path
trackler-2.2.1.110 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.109 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.108 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.107 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.106 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.105 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.104 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.103 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.102 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.101 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.100 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.99 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.98 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.97 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.96 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.95 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.94 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.93 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.92 tracks/ocaml/exercises/atbash-cipher/example.ml
trackler-2.2.1.91 tracks/ocaml/exercises/atbash-cipher/example.ml