Zainspirowany tym wyzwaniem (dzięki za tytuł!
Jak to działa?
Biorąc pod uwagę dwa ciągi znaków (na przykład split
i isbn
), najpierw obetniesz dłuższy ciąg , aby miały jednakową długość, a następnie określisz jego kody ASCII :
split -> spli -> [115, 112, 108, 105]
isbn -> isbn -> [105, 115, 98, 110]
Następnym krokiem będzie zmapowanie ich do zakresu [0..94]
przez odjęcie 32
każdego kodu:
[115, 112, 108, 105] -> [83, 80, 76, 73]
[105, 115, 98, 110] -> [73, 83, 66, 78]
Teraz pomnożysz je modułowo 95
(aby pozostać w zakresie do wydrukowania):
[83, 80, 76, 73] ⊗ [73, 83, 66, 78] -> [74, 85, 76, 89]
Dodaj, 32
aby wrócić do zakresu [32..126]
:
[74, 85, 76, 89] -> [106, 117, 108, 121]
Ostatnim krokiem jest odwzorowanie ich z powrotem na znaki ASCII:
[106, 117, 108, 121] -> "july"
Zasady
- Napisasz program / funkcję, która implementuje opisane kroki na dwóch ciągach i albo wypisuje, albo zwraca wynikowy ciąg
- Format wejściowy jest elastyczny: możesz wziąć dwa ciągi, krotkę ciągów, listę ciągów itp.
- Dane wejściowe mogą składać się z jednego lub dwóch pustych ciągów
- Wprowadzane będą znaki z zakresu do wydrukowania (
[32..126]
) - Dane wyjściowe są drukowane w konsoli lub zwracany jest ciąg znaków
- Dane wyjściowe mogą mieć końcowe białe znaki
Przypadki testowe
"isbn", "split" -> "july"
"", "" -> ""
"", "I don't matter" -> ""
" ", "Me neither :(" -> " "
"but I do!", "!!!!!!!!!" -> "but I do!"
'quotes', '""""""' -> 'ck_iKg'
"wood", "hungry" -> "yarn"
"tray", "gzip" -> "jazz"
"industry", "bond" -> "drop"
"public", "toll" -> "fall"
"roll", "dublin" -> "ball"
"GX!", "GX!" -> "!!!"
"4 lll 4", "4 lll 4" -> "4 lll 4"
"M>>M", "M>>M" -> ">MM>"
Uwaga : cytaty są tylko dla czytelności, w szóstym przypadku testowym, którego użyłem '
zamiast "
.
abc, def -> [['a', 'b', 'c'], ['d', 'e', 'f']]