新学期有一门密码学课,课上老师布置了一道密码学题,题目如下:
解密由仿射密码加密的密文“DBUHU SPANO SMPUS STMIU SBAKN OSMPU SS”
想解密这个密文,首先必须要知道仿射密码是什么:
仿射密码是一种代换密码,加解密公式如下
加密:C=E([a,b],p)=(ap+b) mod 26C=E([a,b],p)=(ap+b) mod 26
解密:p=D([a,b],C)=((C"htmlcode">
#encoding:utf-8 def NI(x,b): #定义求x关于b的逆元的函数NI,其中(NI(x,b)*x) mod b = 1 当x和b互质时求出的逆元唯一 i = 1 while (x*i)%b != 1: i = i + 1 return i c = "DBUHU SPANO SMPUS STMIU SBAKN OSMPU SS" C = [] #对密文进行预处理并储存在列表中,储存形式是对应字母在26个英文字母中的位序 for i in c: if i == ' ': C.append(i) else: C.append(ord(i)-65) #将加密算法中a可能的取值储存在列表中 a = [3,5,7,9,11,15,17,19,21,23,25] P = [] for keyb in range(0,26): for keya in a: ni_a = NI(keya,26) for s in C: if s == ' ': P.append(' ') else: P.append(((s-keyb)*ni_a)%26) #将明文字母对应的位次码依次加入到明文列表中 strP = '' for t in P: if t==' ': strP = strP + ' ' else: strP = strP + chr(t+97) #将明文转化为字符串并输出 print(strP) P = []
运行文件后依次打印出所有可能的明文。经过寻找,发现如下一行应当是所求的明文。
读出明文应当为theres no business like show business。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
更新日志
2024年11月18日
2024年11月18日
- 【雨果唱片】中国管弦乐《鹿回头》WAV
- APM亚流新世代《一起冒险》[FLAC/分轨][106.77MB]
- 崔健《飞狗》律冻文化[WAV+CUE][1.1G]
- 罗志祥《舞状元 (Explicit)》[320K/MP3][66.77MB]
- 尤雅.1997-幽雅精粹2CD【南方】【WAV+CUE】
- 张惠妹.2007-STAR(引进版)【EMI百代】【WAV+CUE】
- 群星.2008-LOVE情歌集VOL.8【正东】【WAV+CUE】
- 罗志祥《舞状元 (Explicit)》[FLAC/分轨][360.76MB]
- Tank《我不伟大,至少我能改变我。》[320K/MP3][160.41MB]
- Tank《我不伟大,至少我能改变我。》[FLAC/分轨][236.89MB]
- CD圣经推荐-夏韶声《谙2》SACD-ISO
- 钟镇涛-《百分百钟镇涛》首批限量版SACD-ISO
- 群星《继续微笑致敬许冠杰》[低速原抓WAV+CUE]
- 潘秀琼.2003-国语难忘金曲珍藏集【皇星全音】【WAV+CUE】
- 林东松.1997-2039玫瑰事件【宝丽金】【WAV+CUE】