我在网上找到了这个Caesar密码加密代码,我试图了解它是如何工作的
#include<stdio.h>
int main()
{
char message[100], ch;
int i, key;
printf("Enter a message to encrypt: ");
gets(message);
printf("Enter key: ");
scanf("%d", &key);
for(i = 0; message[i] != '\0'; ++i){
ch = message[i];
if(ch >= 'a' && ch <= 'z'){
ch = ch + key;
if(ch > 'z'){
ch = ch - 'z' + 'a' - 1;
}
message[i] = ch;
}
else if(ch >= 'A' && ch <= 'Z'){
ch = ch + key;
if(ch > 'Z'){
ch = ch - 'Z' + 'A' - 1;
}
message[i] = ch;
}
}
printf("Encrypted message: %s", message);
return 0;
}
if(ch >= 'a' && ch <= 'z')
的意思就像c包括字母作为数组或某事或如何知道字母是b或其他?ch = ch + key;
中为char添加一个intch = ch - 'Z' + 'A' - 1;
非常感谢
代码为每个输入的字符添加一定的值(key
),如果小帽子和a-z
(如果是大帽子)则“旋转”A-Z
范围内的字符。
在C中,每个单个字符都有一个隐含的ascii/int
值,而compare运算符用于决定输入的字符是否在字符集a-z
(彼此对齐)之后,或者它是否在A-Z
的集合中也跟在后面彼此。
如果输入的字符加上key
“overhoots”f.e,则其余的代码处理环绕。 z
或Z
并通过减去'z'
的值并添加'a' -1
的值来循环它,以便得到的char再次在a-z
或A-Z
的选定范围内的一个