凯撒密码的基本思想是:通过把字母移动一定的位数来实现加密和解密。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推X将变成A,Y变成B,Z变成C。由此可见,位数就是凯撒密码加密和解密的密钥。
本代码使用ASCII码进行转换
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<ctype.h>
int main(void)
{
int x, ch;
printf("输入转换位数:");
scanf("%d", &x);
getchar();//清空输入缓存区
printf("输入密码:");
int i = 0;
while ((ch=getchar())!=EOF)
{
if (isdigit(ch)/*ch >= '0' && ch <= '9'*/)
{
putchar((ch + x - 48) % 10 + 48);
}
else if (islower(ch)/*ch >= 'a' && ch <= 'z'*/)
{
putchar((ch + x - 97) % 26 + 97);
}
else if (isupper(ch)/*ch >= 'A' && ch <= 'Z'*/)
{
putchar((ch + x - 65) % 26 + 65);
}
else
{
putchar(ch);
}
}
return 0;
}