萌新求助
在密码学中,恺撒密码(或称恺撒加密、恺撒变换、变换加密)是一种最简单且最广为人知的加密技术。它是一种替换加密的技术,明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是 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); 输出:a的ASCII码+(ch的ASCII码-a的ASCII码+3)% 26 所对应的字符 xiaosi4081 发表于 2020-8-24 14:54
输出:a的ASCII码+(ch的ASCII码-a的ASCII码+3)% 26 所对应的字符
我主要是对小甲鱼对这道题为什么会这么列式子,就是对这道题列这个式子的思路不明白
本帖最后由 开心小傻猪 于 2020-8-24 15:24 编辑
oooooook 发表于 2020-8-24 15:02
我主要是对小甲鱼对这道题为什么会这么列式子,就是对这道题列这个式子的思路不明白
是不明白ASCII码吗。。。 本帖最后由 昨非 于 2020-8-24 15:25 编辑
oooooook 发表于 2020-8-24 15:02
我主要是对小甲鱼对这道题为什么会这么列式子,就是对这道题列这个式子的思路不明白
ch-'a'得到的是输入字符在26个字母中排的编号(0~25),再加3相当于加密过程,取余26后,没有超过26的编号不变,超过的,拐个弯从头开始(eg:由28到2),再加上a的ASCII码,将编号转换为26个英文字母的真正ASCII码 昨非 发表于 2020-8-24 15:23
ch-'a'得到的是输入字符在26个字母中排的编号(0~25),再加3相当于加密过程,取余26后,没有超过26的 ...
抱歉最佳打错了要不我在问一遍 ? 昨非 发表于 2020-8-24 15:23
ch-'a'得到的是输入字符在26个字母中排的编号(0~25),再加3相当于加密过程,取余26后,没有超过26的 ...
啊这,没大影响吧(我真心想要最佳) 昨非 发表于 2020-8-24 15:26
?
我刚才最佳错了,我建了个新的你再答一遍我给个最佳
oooooook 发表于 2020-8-24 15:29
我刚才最佳错了,我建了个新的你再答一遍我给个最佳
倒是难为你了{:10_266:} 昨非 发表于 2020-8-24 15:30
倒是难为你了
没事,我心里过意不去{:10_277:} 尴尬的是我吧。。。{:10_245:} 开心小傻猪 发表于 2020-8-24 15:22
是不明白ASCII码吗。。。
没事,已经解决了
{:10_266:}
页:
[1]