基本上我需要输入一个输入,将其转换为相应的数字,然后在列表中计算“offset”中输入的内容并返回新的相应数字。
例如对于“de”我会把它翻译成“4”,“5”然后我需要计数到“7”,“8”并让程序返回“gh”。
努力弄清楚如何实际提升名单。
import string
translate = {
'a': "1", 'b': "2", 'c': "3", 'd': "4", 'e': "5", 'f': "6",
'g': "7", 'h': "8", 'i': "9", 'j': "10", 'k': "11", 'l': "12",
'm': "13", 'n': "14", 'o': "15", 'p': "16", 'q': "17", 'r': "18",
's': "19", 't': "20", 'u': "21", 'v': "22", 'w': "23", 'x': "24",
'y': "25", 'z': "26",
}
msg = input("Enter Message: ")
offset = input("Enter Offset: ")
caesar = [translate[ch.lower()] for ch in msg if ch in string.ascii_letters]
答案 0 :(得分:3)
您已导入string
,因此您可以索引string.ascii_letters
而不是手动定义字典并计算偏移量。不要忘记使用modulo从z
到A
。
import string
msg = 'de'
offset = 3
caesar = ''.join(string.ascii_letters[(string.ascii_letters.index(ch) + offset) % len(string.ascii_letters)]
for ch in msg)
print(caesar)
# gh
这可以扩展为稍微更具可读性:
msg = 'de'
offset = 3
caesar = []
for ch in msg:
ch_index = string.ascii_letters.index(ch)
new_index_with_offset = (ch_index + offset) % len(string.ascii_letters)
new_ch = string.ascii_letters[new_index_with_offset]
caesar.append(new_ch)
caesar = ''.join(caesar)
print(caesar)
# gh
我将z
包裹到a
(而不是A
)作为练习给读者留下。