Enigma模拟-Python
设计思想
Enigma机的机械结构:
键盘:加密人员通过键盘进行输入
转子:Enigma机上一般装有至少3个转轮。每个转轮有代表26个字母的触头和触点,触点和触头在转轮内部有导线相连(一个转轮相当于一组单表代替密码),同时外部有棘轮控制转动的幅度。当按动键盘上的单键时,最右边的转轮就会转动一次,每转动26次就会发生进位,带动下一个轮转动。每当转轮转动暂停下来,转轮的触头就会和下一个转轮的触点重新接触,构成通路,按动单键产生的电信号就会经过三个转轮(转轮的触头和下一个转轮的触点有26种接触可能,就是26种通路可能,也就是26张单表)。
反射板:从最后一个转轮出来的电信号会经过反射板,反射板会对信号再次进行置换,接着反射回去,让其再次通过三个转轮,随后输出。
显示板:输出的字母会在显示板上展现,随后会另有机器打印记录。
连接板:设置在机器底部,可以将一对字母短接,相当于是单表加密。
实现的关键:
- 转子作为单表代替密码,可采用随机代替的方式实现。
- 反射器是设计关键,需要保证\(D(a) = b, \quad D(b) = a\),即\(D(D(x))=x\)。
- 转子转动规则为26进1.
python实现
import random
from copy import copy
reflector=[18, 16, 12, 15, 19, 13, 23, 20, 9, 8, 21, 14, 2, 5, 11, 3, 1, 22, 0, 4, 7, 10, 17, 6, 25, 24]
raw_cog=[[6, 10, 23, 9, 19, 2, 21, 1, 7, 24, 0, 17, 15, 3, 8, 4, 14, 12, 16, 25, 11, 18, 22, 20, 13, 5]
,[0, 7, 1, 10, 19, 5, 9, 18, 4, 23, 2, 20, 15, 24, 22, 8, 12, 25, 6, 13, 3, 11, 21, 17, 16, 14]
,[23, 2, 4, 13, 14, 21, 12, 0, 9, 16, 5, 17, 20, 22, 10, 24, 7, 3, 25, 8, 15, 6, 19, 18, 11, 1]]
def shift(List,n):
return List[n:]+List[:n]
class Cog:#模拟转子
def __init__(self,temp):
self.cog=copy(temp)
def rotate(self):
#self.cog=self.cog[1:]+self.cog[:1]
self.cog=shift(self.cog,1)
def printStatus(self):#输出转子当前的状态
for i in self.cog:
print i,
def nextNum(self,x):
return self.cog[x]
def lastNum(self,x):
return self.cog.index(x)
class Enigma:
def __init__(self,cogSum):#cogSum是要使用的转子数
global reflector
self.lenCipher=0 #记录密文长度,计算转子转动
self.cogSum=cogSum
self.cogList=[] #所有使用的转子list
self.reflector=copy(reflector) #反射器
for i in range(0,cogSum):
self.cogList.append(Cog(raw_cog[i]))
def printStatus(self):#输出Enigma密码机当前的状态
for i in range(0,self.cogSum):
print 'cog'+str(self.cogSum)+': '
self.cogList[i].printStatus()
print
print 'reflector:',
for i in self.reflector:
print i,
def dealChar(self,c):#加密一个字符,并且转动转子
#加密字符
num=ord(c)-ord('a')
for i in range(0,self.cogSum):
num=self.cogList[i].nextNum(num)
num=self.reflector[num]
for i in range(self.cogSum-1,-1,-1):
num=self.cogList[i].lastNum(num)
#转动转子
for i in range(0,self.cogSum):
if 26**i<=self.lenCipher and self.lenCipher%26**i==0:
self.cogList[i].rotate()
return chr(ord('a')+num)
def encode(self,oriStr):#字符串的加密,只处理小写英文字母,忽略其他字符
ciphertext=''
oriStr=oriStr.lower()
for eachChar in oriStr:
if eachChar.isalpha():
self.lenCipher+=1
ciphertext+=self.dealChar(eachChar)
return ciphertext
def main():
sumcog=input('请输入要使用的转子数目(最多3个):')
for i in range(0,sumcog):
print '请输入一个0-25的数字以确定第'+str(i+1)+'一个转子起始位置:'
c1=input()
raw_cog[i]=shift(raw_cog[i],c1) #调整转子的初始位子
rawString=raw_input('请输入要加密的字符串')
test=Enigma(sumcog)
temp=test.encode(rawString)
print temp
if __name__ == '__main__':
main()
测试

输入相同字符串:aaaaa,加密后得到zjfns;
再次使用相同设置加密zjfns,得到原字符串aaaaa。
Enigma模拟-Python的更多相关文章
- Mock实现模拟python的对象
Mock库的应用 Mock在Python3.3之前是第三方库,需要安装 pip install Mock :导入 import mock Mock在Python3.3之后是Python标准库,导入方式 ...
- OpenAI 开源机器人模拟 Python 库,并行模拟处理速度提升400%
10000da.cnvboyule.cnjiaeidaypt.cn 在过去一年的研究中,OpenAI团队开源一个使用 MuJoCoengine开发的用于机器人模拟的高性能Python库.雷锋网了解到 ...
- 双摆模拟 python(转)
双摆 是 混沌理论 中的一个常见示例,这里通过 python 的作图工具包Matplotlib 来模拟双摆的运动过程: 注意:在 vs2017 中可以正确运行程序,在 cmd 环境下有时报错 &quo ...
- [ZOJ 1009] Enigma (模拟)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1009 题目大意:给你三个转换轮,只有当第一个转换轮转动一圈后第二 ...
- 模拟python中的Yield伪并发
并发,在操作系统中,是指一个时间段中有几个程序都处于已启动运行到运行完毕之间,且这几个程序都是在同一个处理机上运行,但任一个时刻点上只有一个程序在处理机上运行. #Yield伪并发 _author_= ...
- C++模拟python风格的print函数--打印vector,map,list等结构
// 最基本实现 template<typename T> static void print(T t) { std::cout << t; } // 处理 std::pair ...
- Python 的mock模拟测试介绍
如何不靠耐心测试 可能我们正在写一个社交软件并且想测试一下"发布到Facebook的功能",但是我们不希望每次运行测试集的时候都发布到Facebook上. Python的unitt ...
- Python学习--04条件控制与循环结构
Python学习--04条件控制与循环结构 条件控制 在Python程序中,用if语句实现条件控制. 语法格式: if <条件判断1>: <执行1> elif <条件判断 ...
- CoffeeScript实现Python装潢器
在上篇Angular遇上CoffeeScript – NgComponent封装中,我们讲述了CoffeeScript这门小巧的语言,摒弃JavaScript中糟粕(“坑”)部分,并将JavaScri ...
随机推荐
- 很实用的HTML5+CSS3注册登录窗体切换效果
1. [代码]3个很实用的HTML5+CSS3注册登录窗体切换效果 <!DOCTYPE html><!--[if lt IE 7 ]> <html lang=" ...
- jmeter 多压力机并发测试过程
要实现多台压力机并发,就必须有多台服务器上安装了jmeter程序包,首先把一台服务器作为主压力机,测试脚本放到这台机器上,主压力机与从压力机在同一局域网中,服务器之间可以ping通 第一步:在linu ...
- KVM-快照管理
1.kvm克隆 kvm 虚拟机有两部分组成:img镜像文件和xml配置文件(/etc/libvirt/qemu 克隆命令:virt-clone -o rhel6- 71 -n xuegod63-kvm ...
- 【leetcode刷题笔记】Remove Nth Node From End of List
Given a linked list, remove the nth node from the end of list and return its head. For example, Give ...
- HTML5视音频标签参考
本文将介绍HTML5中的视音频标签和对应的DOM对象.是相关资料的中文化版本,可以作为编写相关应用的简易中文参考手册. 一些约定 所有浏览器:指支持HTML5的常见桌面浏览器,包括IE9+.Firef ...
- 【转】Lucas定理 & 逆元学习小结
(From:离殇灬孤狼) 这个Lucas定理是解决组合数的时候用的,当然是比较大的组合数了.比如C(1000000,50000)% mod,这个mod肯定是要取的,要不算出来真的是天文数字了. 对于一 ...
- BZOJ4976: [Lydsy1708月赛]宝石镶嵌
BZOJ4976: [Lydsy1708月赛]宝石镶嵌 https://lydsy.com/JudgeOnline/problem.php?id=4976 分析: 本来是从\(k\le 100\)这里 ...
- Java如何调用dll
-----------------------------前置条件------------------------------------- 1. 首先有testdll.dll 2. 需要testdl ...
- DOM基础知识整理
--<JavaScript高级程序设计>Chapter10学习笔记 一.节点层次 1.Node类型 1)(Node).nodeType属性 节点nodeType属性有12种. 检测node ...
- Poj 3356 ACGT(LCS 或 带备忘的递归)
题意:把一个字符串通过增.删.改三种操作变成另外一个字符串,求最少的操作数. 分析: 可以用LCS求出最大公共子序列,再把两个串中更长的那一串中不是公共子序列的部分删除. 分析可知两个字符串的距离肯定 ...