维吉尼亚密码

维吉尼亚密码属于多表代换密码

其中A<-->0,B<-->1,...,Z<-->25,则每个密钥K相当于一个长度为m的字母串,称为密钥字。维吉尼亚密码一次加密m个明文字母。

示例:设m=6,密钥字为"CIPHER",对应数字串K=(2,8,15,7,4,17)。要加密明文为:thiscrypto,则
则相应的密文为:VPXZGIAXIV

解密时,使用相同的密钥字进行逆运算即可。

可以看出,维吉尼亚密码的密钥空间为26^m。

加密:

python 复制代码
Plaintext = 'THISCRYPTO'#字母需要大写
K = [2,8,15,7,4,17]

#print(K)#密钥

Ciphertext = ''
for i in range(len(Plaintext)):
    M_i = ord(Plaintext[i]) - 65 
    K_i = K[i%len(K)]
    C_i = (M_i+K_i)%26
    Ciphertext += chr(C_i+ 65) 
print(Ciphertext)

解密:

python 复制代码
Ciphertext = 'VPXZGIAXIV'   
K = [2,8,15,7,4,17]

Plaintext = ''
for i in range(len(Ciphertext)):
    C_i = ord(Ciphertext[i]) -65 
    K_i = K[i%len(K)]
    M_i = (C_i - K_i)%26
    Plaintext += chr(M_i+ 65) 
print(Plaintext)
相关推荐
Liknana3 分钟前
动态渲染页面爬取
python
凤枭香12 分钟前
Python Scikit-learn简介
开发语言·python·机器学习·scikit-learn
人生!?15 分钟前
爬虫实战:采集知乎XXX话题数据
爬虫·python
数据岛17 分钟前
sklearn中常用数据集简介
人工智能·python·sklearn
微蓝课堂26 分钟前
【微蓝课堂】机器人编程|树莓派系列|13-从零开始编写TM1637驱动程序
笔记·python·青少年编程·机器人
zaim130 分钟前
计算机的错误计算(一百六十三)
java·c++·python·matlab·错数·等价算式
寒雒34 分钟前
【Python】实战:实现GUI登录界面
开发语言·前端·python
好看资源平台40 分钟前
网络爬虫——常见问题与调试技巧
爬虫·python
Dreams°1231 小时前
【大数据测试Flume:从 0-1详细教程】
大数据·python·单元测试·自动化·flume
stormsha2 小时前
go-rod vs Selenium:自动化测试工具的比较与选择
python·selenium·测试工具·golang