最近看了一部电影,叫《模仿游戏》,主要讲的就是二战期间图灵破解德军通讯密码的故事,最后的意义是导致二战提前两年结束,拯救了至少1400万人的生命。然后自己一时兴起就写了一个单表随机排列的恩格玛机,很有意思。代码如下,自取
import random
Alphabet="ABCDEFGHIJKLMNOPQRSTUVWXYZ"
a_list=[]
E1_list=[]
key_list=[]
text_in=str.upper(input("What's your text: "))
for a in Alphabet:
a_list.append(a)
o_list.append(a)
def not_sort(E):
for i in range(len(a_list)):
key_list.append(i)
random.shuffle(key_list)
for _ in key_list:
E.append(a_list[_])#将i 也就是1-25的顺序全部打乱作为索引 意味着打乱A-Z的所有顺序 并且放入E全局变量
not_sort(E1_list)
for t1 in text_in:
if t1 in a_list:
t1=(E1_list[a_list.index(t1)])
else:
t1= "-" or "!"
print(str.lower(t1),end="")#分别提取输入明文的各个字母 并且按照表1进行替换
text_out=str.upper(input("\nWhat's your text: "))
for t2 in text_out:
if t2 in a_list:
t2=(a_list[E1_list.index(t2)])
elif t2 == "-" or "!":
t2=" "
print(str.lower(t2),end="")#分别提取暗文的各个字母 按照表1进行恢复