blob: 96aba6ea78cab12ad9d98d419fbd25cddffa5669 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
#lang racket
(define/contract (replace-digits s)
(-> string? string?)
(define/contract (shift-letter c x)
(-> char? char? char?)
(integer->char (+ (string->number (string x)) (char->integer c))))
(define letters (string->list (string-replace s #rx"[0-9]" "")))
(define digits (string->list (string-replace s #rx"[a-z]" "")))
(foldl (λ (c x acc)
(if (equal? x #\X)
(string-append acc (string c))
(string-append acc (string c) (string (shift-letter c x)))))
""
letters
(if (= (length digits) (length letters))
digits
(append digits '(#\X)))
))
|