Python 凯撒密码

本文介绍了凯撒密码的实现,包括其Python实现类`CaesarCipher`,该类支持自定义字母表和偏移量。通过`encode`方法,可以对输入的字符串进行加密。特别地,ROT13是一种特殊的凯撒密码,偏移量为13,由于字母表长度为26,ROT13具有自我解密性质:ROT13(ROT13(s))=s。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

凯撒密码

class CaesarCipher:
    def __init__(self, alphabet, shift):
        self.alphabet = alphabet
        self.asize = len(alphabet)
        self.shift = shift
        self._dict = {}
        for i, c in enumerate(ALPHABET):
            self._dict[c] = i
    
    def _encode(self, c):
        return self.alphabet[(self._dict[c]+self.shift)%self.asize]
    
    
    def encode(self, s):
        o = ''
        for c in s:
            o += self._encode(c)
        return o

if __name__ == '__main__':
	ALPHABET = 'abcdefghijklmnopqrstuvwxyz'
    cipher = CaesarCipher(ALPHABET, 3)
    code = cipher.encode('hello')
    print(code)

ROT13

即把 凯撒密码 的偏置参数设成 13,由于字母表的长度为 26,故 ROT13 既是加密算法,也是解密算法:
ROT13(ROT13(s))=s ROT13(ROT13( s )) = s ROT13(ROT13(s))=s

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

颹蕭蕭

白嫖?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值