在密码学中,恺撒密码(或称恺撒加密、恺撒变换、变换加密)是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。
例如,当偏移量是 +3 的时候,所有的字母 A 将被替换成 D,B 变成 E,以此类推。这个加密方法是以恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。
程序要求:用户输入一行明文(字符串),针对字母进行加密(偏移量设置为 3),非字母部分保留原型。
输入:
Today, we make history!
输出:
Wrgdb, zh pdnh klvwrub!
难点:
后边几个字母加上偏移后需要变成前边的字母,比如 x -> a,y -> b,z -> c。 如果像前面23个字母那样直接向后偏移三位后,得到的将不是英文字母,而是ASCII表中对应的符号{, |, }。
解决方法:
我们在使用凯撒密码将字母char向后移动x位的时候,会很自然地将后面的字母移动a位,从而使char对应到字母z,然后再将char移动x - a位,来完成这一次密码转换。
我们需要让计算机也能够自动地完成这一命令,同时不破坏替换靠前的字母的输出结果。
使用余数来实现这一目标。
putchar('a' + (ch - &#