65 lines
1.2 KiB
Python
65 lines
1.2 KiB
Python
|
# generate a flat binary tree for morse decoding
|
||
|
|
||
|
from functools import reduce
|
||
|
|
||
|
# https://stackoverflow.com/questions/71099952
|
||
|
encode_table = {
|
||
|
"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": "--..",
|
||
|
"0": "-----",
|
||
|
"1": ".----",
|
||
|
"2": "..---",
|
||
|
"3": "...--",
|
||
|
"4": "....-",
|
||
|
"5": ".....",
|
||
|
"6": "-....",
|
||
|
"7": "--...",
|
||
|
"8": "---..",
|
||
|
"9": "----.",
|
||
|
".": ".-.-.-",
|
||
|
",": "--..--",
|
||
|
"?": "..--..",
|
||
|
"\\n": "-..-..",
|
||
|
"\\b": ".-.-",
|
||
|
"\\e": "..--",
|
||
|
" ": "----",
|
||
|
}
|
||
|
|
||
|
maxLen = reduce(lambda x, y: max(x, y), [len(code) for code in encode_table.values()])
|
||
|
|
||
|
letters = ['*'] + ['*'] * 2**(maxLen + 1)
|
||
|
|
||
|
for sym, code in encode_table.items():
|
||
|
idx = 1
|
||
|
for lett in code:
|
||
|
idx *= 2
|
||
|
if lett == '-':
|
||
|
idx += 1;
|
||
|
letters[idx] = sym
|
||
|
|
||
|
print("".join(letters))
|