萌新求助
在密码学中,恺撒密码(或称恺撒加密、恺撒变换、变换加密)是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是 3 的时候,所有的字母 A 将被替换成 D,B 变成 E,以此类推。这个加密方法是以恺撒的名字命名的,当年恺撒曾用此方法与其将军们进行联系。
要求:用户输入一行明文(字符串),针对字母进行加密(偏移量设置为 3),非字母部分保留原型。
注意:字母 y 应该被替换为字母 b,而字母 z 应该被替换为字母 c。
#include <stdio.h>
int main()
{
int ch;
printf("请输入明文:");
while ((ch = getchar()) != '\n')
{
if (ch >= 'a' && ch <= 'z')
{
putchar('a' + (ch - 'a' + 3) % 26);
continue;
}
if (ch >= 'A' && ch <= 'Z')
{
putchar('A' + (ch - 'A' + 3) % 26);
continue;
}
putchar(ch);
}
putchar('\n');
return 0;
}
这个计算是什么意思求讲解 putchar('a' + (ch - 'a' + 3) % 26); ch-'a'得到的是输入字符在26个字母中排的编号(0~25),再加3相当于加密过程,取余26后,没有超过26的编号不变,超过的,拐个弯从头开始(eg:由28到2),再加上a的ASCII码,将编号转换为26个英文字母的真正ASCII码 (这次算我贪个小便宜,不过没有特殊情况建议不要发重复贴,顺带说一句,
搞得我还有点愧疚。。。) 昨非 发表于 2020-8-24 15:32
(这次算我贪个小便宜,不过没有特殊情况建议不要发重复贴,顺带说一句,
搞得我还有点愧疚。。。)
ok
本帖最后由 风过无痕1989 于 2020-8-24 15:42 编辑
第一个 'a' 是为了保证所输入的数在 a ~ z 之间,(ch - 'a' + 3) % 26 是为保证你无论输入多大的数,需要的只是26 (字母有26个) 的余数,也就是这个在 0 ~ 26(不凶手26)。
比如:你输入 888 ,( 888 - 97 + 3 ) % 26 = 794 % 26 = 14 , 它就是字母 o oooooook 发表于 2020-8-24 15:33
ok
没事,我只是想再给他举个例子,故而重新编辑一下,没想到,我编辑完了,最佳也已经定了 风过无痕1989 发表于 2020-8-24 15:45
没事,我只是想再给他举个例子,故而重新编辑一下,没想到,我编辑完了,最佳也已经定了
hhh晚了一步{:10_256:} 昨非 发表于 2020-8-24 15:32
(这次算我贪个小便宜,不过没有特殊情况建议不要发重复贴,顺带说一句,
搞得我还有点愧疚。。。)
我加不了好友等级不够,等等级够了一定加你{:10_277:} oooooook 发表于 2020-8-24 16:09
我加不了好友等级不够,等等级够了一定加你
没事,没事,我都忘了{:10_257:}
页:
[1]