题目8:编写程序,实现凯撒加密。

凯撒加密方法:

是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。这个加密方法是以罗马共和时期恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。

编写程序如下:

def kaisa(text,k):
    s1 = 'abcdefghijklmnopqrstuvwxyz'
    s2 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'
    s1later = s1[k:] + s1[:k]
    s2later = s2[k:] + s2[:k]
    table = ''.maketrans(s1+s2,s1later+s2later)
    return text.translate(table)

这里用了maketrans()函数和translate()函数

maketrans()函数用来形成字符的对照关系,以上面的代码为例,

输入

print(dict(table))

以k=3为例,可以得出下列映射关系,

{97: 100, 98: 101, 99: 102, 100: 103, 101: 104, 102: 105, 103: 106, 104: 107, 105: 108, 106: 109, 107: 110, 108: 111, 109: 112, 110: 113, 111: 114, 112: 115, 113: 116, 114: 117, 115: 118, 116: 119, 117: 120, 118: 121, 119: 122, 120: 97, 121: 98, 122: 99, 65: 68, 66: 69, 67: 70, 68: 71, 69: 72, 70: 73, 71: 74, 72: 75, 73: 76, 74: 77, 75: 78, 76: 79, 77: 80, 78: 81, 79: 82, 80: 83, 81: 84, 82: 85, 83: 86, 84: 87, 85: 88, 86: 89, 87: 90, 88: 65, 89: 66, 90: 67}

这里是字符的ACSII码。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值