美文网首页密码
习题6:破解摩斯密码

习题6:破解摩斯密码

作者: 今年说话算话 | 来源:发表于2017-02-21 18:46 被阅读37次
    The Morse code encodes every character as a sequence of "dots" and "dashes". For example, the letter A is coded as ·−, letter Q is coded as −−·−, and digit 1 is coded as ·−−−. The Morse code is case-insensitive, traditionally capital letters are used. When the message is written in Morse code, a single space is used to separate the character codes and 3 spaces are used to separate words. For example, the message HEY JUDE in Morse code is ···· · −·−− ·−−− ··− −·· ·.
    
    NOTE: Extra spaces before or after the code have no meaning and should be ignored.
    
    In addition to letters, digits and some punctuation, there are some special service codes, the most notorious of those is the international distress signal SOS (that was first issued by Titanic), that is coded as ···−−−···. These special codes are treated as single special characters, and usually are transmitted as separate words.
    

    def decodeMorse(morseCode):
    # ToDo: Accept dots, dashes and spaces, return human-readable message
    MORSE_CODE = {'.-': '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',
    '...---...': 'sos',
    '.-.-.-': '.',
    '-.-.--': '!'}
    content = ''
    word_list = morseCode.split(' ')
    for word in word_list:
    s = ''
    for alpha in word.split():
    s += MORSE_CODE[alpha]
    content += ' ' + s
    return content.strip().upper()

    相关文章

      网友评论

      本文标题:习题6:破解摩斯密码

      本文链接:https://www.haomeiwen.com/subject/hhpuwttx.html