Morse code is a method of transmitting text information as a series of on-off tones, lights, or clicks that can be directly understood by a skilled listener or observer without special equipment. It is named for Samuel F. B. Morse, an inventor of the telegraph.
The algorithm is very simple. Every character in the English language is substituted by a series of ‘dots’ and ‘dashes’ or sometimes just singular ‘dot’ or ‘dash’ and vice versa.
Please refer this wikipedia image for details.
- In case of encryption we extract each character (if not a space) from a word one at a time and match it with its corresponding morse code stored in whichever data structure we have chosen(if you are coding in python, dictionaries can turn out to be very useful in this case)
- Store the morse code in a variable which will contain our encoded string and then we add a space to our string which will contain the result.
- While encoding in morse code we need to add 1 space between every character and 2 consecutive spaces between every word.
- If the character is a space then add another space to the variable containing the result. We repeat this process till we traverse the whole string
- In case of decryption, we start by adding a space at the end of the string to be decoded (this will be explained later).
- Now we keep extracting characters from the string till we are not getting any space.
- As soon as we get a space we look up the corresponding English language character to the extracted sequence of characters (or our morse code) and add it to a variable which will store the result.
- Remember keeping track of the space is the most important part of this decryption process. As soon as we get 2 consecutive spaces we will add another space to our variable containing the decoded string.
- The last space at the end of the string will help us identify the last sequence of morse code characters (since a space acts as a check for extracting characters and start decoding them).
Python provides a data structure called dictionary which stores information in the form of key-value pairs which is very convenient for implementing a cipher such as the morse code. We can save the morse code chart in a dictionary where (key-value pairs) => (English Characters-Morse Code). The plaintext (English characters) take the place of keys and the ciphertext (Morse code) form the values of the corresponding keys. The values of keys can be accessed from the dictionary in the same way we access the values of an array through their index and vice versa.
Output: --. . . -.- ... -....- ..-. --- .-. -....- --. . . -.- ... GEEKS-FOR-GEEKS
This article is contributed by Palash Nigam . If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to firstname.lastname@example.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.
- Python - Morse Code Translator GUI using Tkinter
- Language Translator Using Google API in Python
- Project Idea | Audio to Sign Language Translator
- Project Idea | Sign Language Translator for Speech-Impaired
- Reusable piece of python functionality for wrapping arbitrary blocks of code : Python Context Managers
- Code Golfing in Python
- Issues with using C code in Python | Set 1
- Python code to convert SOP to POS
- Code introspection in Python
- Cryptophasia Code in Python
- code.compile_command() in Python
- Issues with using C code in Python | Set 2
- Top 10 Python IDE and Code Editors in 2020
- How to run Python code on Google Colaboratory
- How to clone a method code in Python?
- Python code formatting using Black
- Optimization Tips for Python Code
- Different Python IDEs and Code Editors
- Change your way to put logic in your code - Python
- Execute a String of Code in Python