单表恩格玛机的源码实现
最近看了一部电影,叫《模仿游戏》,主要讲的就是二战期间图灵破解德军通讯密码的故事,最后的意义是导致二战提前两年结束,拯救了至少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进行恢复
上一篇:
IDEA上Java项目控制台中文乱码