diff options
| author | Paulo Custodio <pauloscustodio@gmail.com> | 2024-08-31 11:15:00 +0100 |
|---|---|---|
| committer | Paulo Custodio <pauloscustodio@gmail.com> | 2024-08-31 11:15:00 +0100 |
| commit | 5fd0e13ee01e48f3d8b10f02f42b58bcdcca157e (patch) | |
| tree | 9c1fd6c1b73da884fdbc7d0fbce8327e60c2e02d /challenge-045/paulo-custodio/python/ch-1.py | |
| parent | e5b5d21abbae5d4dd147ec2bf9d9cec96457c744 (diff) | |
| download | perlweeklychallenge-club-5fd0e13ee01e48f3d8b10f02f42b58bcdcca157e.tar.gz perlweeklychallenge-club-5fd0e13ee01e48f3d8b10f02f42b58bcdcca157e.tar.bz2 perlweeklychallenge-club-5fd0e13ee01e48f3d8b10f02f42b58bcdcca157e.zip | |
Add Python solution to challenge 045
Diffstat (limited to 'challenge-045/paulo-custodio/python/ch-1.py')
| -rw-r--r-- | challenge-045/paulo-custodio/python/ch-1.py | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/challenge-045/paulo-custodio/python/ch-1.py b/challenge-045/paulo-custodio/python/ch-1.py new file mode 100644 index 0000000000..a6417710be --- /dev/null +++ b/challenge-045/paulo-custodio/python/ch-1.py @@ -0,0 +1,51 @@ +#!/usr/bin/env python3 + +# Challenge 045 +# +# TASK #1 +# Square Secret Code +# +# The square secret code mechanism first removes any space from the original +# message. Then it lays down the message in a row of 8 columns. The coded +# message is then obtained by reading down the columns going left to right. +# +# For example, the message is "The quick brown fox jumps over the lazy dog". +# +# Then the message would be laid out as below: +# +# thequick +# brownfox +# jumpsove +# rthelazy +# dog +# +# The code message would be as below: +# +# tbjrd hruto eomhg qwpe unsl ifoa covz kxey +# +# Write a script that accepts a message from command line and prints the +# equivalent coded message. + +import re +import sys + +def encode(text): + text, dummy = re.subn(r'\W+', '', text) + box = [] + while text != '': + box.append(text[0:8]) + text = text[8:] + encoded = [] + while True: + box = [x for x in filter(lambda x: x != '', box)] + if len(box) == 0: + break; + word = "" + for i in range(len(box)): + if len(box[i]) > 0: + word += box[i][0] + box[i] = box[i][1:] + encoded.append(word) + return encoded + +print(' '.join(encode(''.join(sys.argv[1:])))) |
