当p为字母z时,试一下直接ord(p)+3就知道啦。
我假设老哥你已经懂了python语法,我就只讲讲凯撒加密。凯撒加密说白了就是偏移字母的位置,将原来的字母用它之后的第x个字母来代替原来的字母进行加密。因此这个加密方法仅仅支持纯英文字母。
举个简单的例子,假如明文是“Hello World”,那么经过偏移量(或者称之为密钥)为3的凯撒加密后,就会变成“Khoor Zruog”。
下面来看代码,char里面分为两部分第一部分为ord(“a”),第二部分为(ord(p)-ord(“a”)+3)%26
第二部分的意思是什么?是先用原始字母减去字母a,记得数为n,实际上也就是得到p是第n+1个字母,然后加上偏移量3,表示要将p加密为第n+4个字母。为什么最后要对26取模。很简单,为了照顾x,y,z的心情。这样就可以通过取模运算将他们对应到abc上了。好了现在第二部分的结果实际上是(n+3)%26,他表示加密后的字母距离字母a的距离为(n+3)%26
接下来将上面的结果加上a的ascii码也就是第一部分,不就得到了新的加密后的字母的ascii码了吗,然后char一下,完成!
希望我的回答可以帮助到你。