维吉尼亚密码

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

其中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)
相关推荐
Gerlat小智34 分钟前
【Python精讲 16】实战项目演练(二):用Flask/FastAPI发布你的第一个Web API
python·flask·fastapi
fenghx2581 小时前
vscode使用arcpy-选择arcgis带的python+运行错误解决
vscode·python·arcgis
王嘉俊9251 小时前
Flask 入门:轻量级 Python Web 框架的快速上手
开发语言·前端·后端·python·flask·入门
爱刘温柔的小猪1 小时前
Python 基于 MinIO 的文件上传服务与图像处理核心实践
python·minio
(●—●)橘子……1 小时前
记力扣2271.毯子覆盖的最多白色砖块数 练习理解
数据结构·笔记·python·学习·算法·leetcode
做运维的阿瑞1 小时前
Python 面向对象编程深度指南
开发语言·数据结构·后端·python
木木子99992 小时前
Python的typing模块:类型提示 (Type Hinting)
开发语言·windows·python
MediaTea2 小时前
Python 编辑器:PyCharm
开发语言·ide·python·pycharm·编辑器
小熊出擊2 小时前
[pytest] 一文掌握 fixture 的作用域(scope)机制
python·功能测试·单元测试·自动化·pytest
Cherry Zack2 小时前
Django 视图与路由基础:从URL映射到视图函数
后端·python·django