单表恩格玛机的源码实现

最近看了一部电影,叫《模仿游戏》,主要讲的就是二战期间图灵破解德军通讯密码的故事,最后的意义是导致二战提前两年结束,拯救了至少1400万人的生命。然后自己一时兴起就写了一个单表随机排列的恩格玛机,很有意思。代码如下,自取

import random
Alphabet="ABCDEFGHIJKLMNOPQRSTUVWXYZ"
a_list=[]
E1_list=[]
key_list=[]
text_in=str.upper(input("Whats 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("
Whats 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进行恢复
经验分享 程序员 微信小程序 职场和发展