diff options
| author | Conor Hoekstra <codereport@outlook.com> | 2021-12-28 17:13:22 -0500 |
|---|---|---|
| committer | Conor Hoekstra <codereport@outlook.com> | 2021-12-28 17:13:22 -0500 |
| commit | 7d13afd3d3b2ba151d99a1d694d0906711ce9ead (patch) | |
| tree | b2faf3227040bd3967011050d611e4f720540123 /challenge-035 | |
| parent | 6e08a3189797e123107f7e6944f43ff5d9cab9bd (diff) | |
| parent | c524a3754a9f0a685a84c2dfdeea58b36e85f512 (diff) | |
| download | perlweeklychallenge-club-7d13afd3d3b2ba151d99a1d694d0906711ce9ead.tar.gz perlweeklychallenge-club-7d13afd3d3b2ba151d99a1d694d0906711ce9ead.tar.bz2 perlweeklychallenge-club-7d13afd3d3b2ba151d99a1d694d0906711ce9ead.zip | |
Merge branch 'master' of https://github.com/manwar/perlweeklychallenge-club
Diffstat (limited to 'challenge-035')
| -rw-r--r-- | challenge-035/paulo-custodio/Makefile | 2 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/README | 1 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/perl/ch-1.pl | 38 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/perl/ch-2.pl | 30 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/python/ch-1.py | 47 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/python/ch-2.py | 47 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/t/test-1.yaml | 5 | ||||
| -rw-r--r-- | challenge-035/paulo-custodio/t/test-2.yaml | 5 |
8 files changed, 175 insertions, 0 deletions
diff --git a/challenge-035/paulo-custodio/Makefile b/challenge-035/paulo-custodio/Makefile new file mode 100644 index 0000000000..c3c762d746 --- /dev/null +++ b/challenge-035/paulo-custodio/Makefile @@ -0,0 +1,2 @@ +all: + perl ../../challenge-001/paulo-custodio/test.pl diff --git a/challenge-035/paulo-custodio/README b/challenge-035/paulo-custodio/README new file mode 100644 index 0000000000..87dc0b2fbd --- /dev/null +++ b/challenge-035/paulo-custodio/README @@ -0,0 +1 @@ +Solution by Paulo Custodio diff --git a/challenge-035/paulo-custodio/perl/ch-1.pl b/challenge-035/paulo-custodio/perl/ch-1.pl new file mode 100644 index 0000000000..1346f11cbf --- /dev/null +++ b/challenge-035/paulo-custodio/perl/ch-1.pl @@ -0,0 +1,38 @@ +#!/usr/bin/perl + +# Challenge 035 +# +# TASK #1 +# Contributed by Paul Johnson +# Write a program to encode text into binary encoded morse code. +# Pay attention to any changes which might need to be made to the text to +# make it valid morse code. +# +# Morse code consists of dots, dashes and gaps. It can be encoded in binary +# in the following fashion: +# +# dot: 1 +# dash: 111 +# intra-character gap: 0 +# character gap: 000 +# word gap: 0000000 +# An intra-character gap is inserted between the dots and dashes in a character. + +use Modern::Perl; +use Text::Morse; + +sub encode_bin_morse { + my($text) = @_; + my $morse = Text::Morse->new; + my $encoded = $morse->Encode($text); # ' ' between chars, '\n' between words + for ($encoded) { + s/\./10/g; # . = 1 + 0 gap + s/\-/1110/g; # - = 111 + 0 gap + s/ /00/g; # inter-word = 000 - 0 gap + s/\n/0000/g; # word gap = 0000000 - 00 - 0 + s/0+$// # remove trailing zeros + } + return $encoded; +} + +say encode_bin_morse("@ARGV"); diff --git a/challenge-035/paulo-custodio/perl/ch-2.pl b/challenge-035/paulo-custodio/perl/ch-2.pl new file mode 100644 index 0000000000..1450b46fed --- /dev/null +++ b/challenge-035/paulo-custodio/perl/ch-2.pl @@ -0,0 +1,30 @@ +#!/usr/bin/perl + +# Challenge 035 +# +# TASK #2 +# Contributed by Paul Johnson +# Write a program to decode binary morse code. +# Consider how it might be possible to recover from badly formed morse code. +# +# a) by splitting the morse code on gaps +# b) without looking further than one digit ahead + +use Modern::Perl; +use Text::Morse; + +sub decode_bin_morse { + my($encoded) = @_; + for ($encoded) { + s/0+$//; # remove trailing zeros + s/0000000/\n/g; # word gap + s/000/ /g; # character gap + s/1110?/-/g; # - + s/10?/./g; # . + } + my $morse = Text::Morse->new; + my $text = $morse->Decode($encoded); + return $text; +} + +say decode_bin_morse("@ARGV"); diff --git a/challenge-035/paulo-custodio/python/ch-1.py b/challenge-035/paulo-custodio/python/ch-1.py new file mode 100644 index 0000000000..f0ce1e091d --- /dev/null +++ b/challenge-035/paulo-custodio/python/ch-1.py @@ -0,0 +1,47 @@ +#!/usr/bin/python3 + +# Challenge 035 +# +# TASK #1 +# Contributed by Paul Johnson +# Write a program to encode text into binary encoded morse code. +# Pay attention to any changes which might need to be made to the text to +# make it valid morse code. +# +# Morse code consists of dots, dashes and gaps. It can be encoded in binary +# in the following fashion: +# +# dot: 1 +# dash: 111 +# intra-character gap: 0 +# character gap: 000 +# word gap: 0000000 +# An intra-character gap is inserted between the dots and dashes in a character. + +import sys +import re + +# morse code chart +MORSE = { 'A':'.-', 'B':'-...', 'C':'-.-.', 'D':'-..', 'E':'.', + 'F':'..-.', 'G':'--.', 'H':'....', 'I':'..', 'J':'.---', + 'K':'-.-', 'L':'.-..', 'M':'--', 'N':'-.', 'O':'---', + 'P':'.--.', 'Q':'--.-', 'R':'.-.', 'S':'...', 'T':'-', + 'U':'..-', 'V':'...-', 'W':'.--', 'X':'-..-', 'Y':'-.--', + 'Z':'--..', '1':'.----', '2':'..---', '3':'...--', '4':'....-', + '5':'.....', '6':'-....', '7':'--...', '8':'---..', '9':'----.', + '0':'-----'} + +def encode_bin_morse(text): + encoded = "" + for c in text.upper(): + if c.isalnum(): + morse = MORSE[c] + morse = re.sub(r"\.", "10", morse) + morse = re.sub(r"\-", "1110", morse) + encoded += morse+"00" + else: + encoded += "0000" + encoded = re.sub(r"0+$", "", encoded) + return encoded + +print(encode_bin_morse(" ".join(sys.argv[1:]))) diff --git a/challenge-035/paulo-custodio/python/ch-2.py b/challenge-035/paulo-custodio/python/ch-2.py new file mode 100644 index 0000000000..f38b35a5bb --- /dev/null +++ b/challenge-035/paulo-custodio/python/ch-2.py @@ -0,0 +1,47 @@ +#!/usr/bin/python3 + +# Challenge 035 +# +# Challenge 035 +# +# TASK #2 +# Contributed by Paul Johnson +# Write a program to decode binary morse code. +# Consider how it might be possible to recover from badly formed morse code. +# +# a) by splitting the morse code on gaps +# b) without looking further than one digit ahead + +import sys +import re + +# morse code chart +MORSE = { 'A':'.-', 'B':'-...', 'C':'-.-.', 'D':'-..', 'E':'.', + 'F':'..-.', 'G':'--.', 'H':'....', 'I':'..', 'J':'.---', + 'K':'-.-', 'L':'.-..', 'M':'--', 'N':'-.', 'O':'---', + 'P':'.--.', 'Q':'--.-', 'R':'.-.', 'S':'...', 'T':'-', + 'U':'..-', 'V':'...-', 'W':'.--', 'X':'-..-', 'Y':'-.--', + 'Z':'--..', '1':'.----', '2':'..---', '3':'...--', '4':'....-', + '5':'.....', '6':'-....', '7':'--...', '8':'---..', '9':'----.', + '0':'-----'} + +MORSE_INV = {v:k for k, v in MORSE.items()} + +def decode_bin_morse(encoded): + encoded = re.sub(r"0+$", "", encoded) # remove trailing 0s + encoded = re.sub(r"0000000", "\n", encoded) # word gap + encoded = re.sub(r"000", " ", encoded) # character gap + encoded = re.sub(r"1110?", "-", encoded) # - + encoded = re.sub(r"10?", ".", encoded) # . + + text = "" + words = encoded.split("\n") + for word in words: + chars = word.split() + for c in chars: + text += MORSE_INV[c] + text += " " + text = re.sub(r"\s+$", "", text) + return text + +print(decode_bin_morse(" ".join(sys.argv[1:]))) diff --git a/challenge-035/paulo-custodio/t/test-1.yaml b/challenge-035/paulo-custodio/t/test-1.yaml new file mode 100644 index 0000000000..a26ea529b6 --- /dev/null +++ b/challenge-035/paulo-custodio/t/test-1.yaml @@ -0,0 +1,5 @@ +- setup: + cleanup: + args: MORSE CODE + input: + output: 11101110001110111011100010111010001010100010000000111010111010001110111011100011101010001 diff --git a/challenge-035/paulo-custodio/t/test-2.yaml b/challenge-035/paulo-custodio/t/test-2.yaml new file mode 100644 index 0000000000..9955ded934 --- /dev/null +++ b/challenge-035/paulo-custodio/t/test-2.yaml @@ -0,0 +1,5 @@ +- setup: + cleanup: + args: 11101110001110111011100010111010001010100010000000111010111010001110111011100011101010001 + input: + output: MORSE CODE |
