凯撒密码
欢迎进入我的C语言世界
题目
Problem Description
在人类历史上,对信息保护的需求与对信息本身的需求一样久远。第一个用于加密和解密文本的编码方式是凯撒密码。凯撒密码约定的规则是,源文本中每个英文字母都被英文字母表中该字母后第三个位置的字母替换。例如,A->D, B->E, X->A, z->c。所有其他的符号都保持不变。现在请你写一个程序将加密后的文本解密。题目中大小写英文字母表分开,各自形成一个循环表。
Input
本题有多组输入数据,每组数据只有一行,表示加密后的文字,由字母、空格、数字以及各种标点组成,文字长度不超过80个字符。
Output
对于每组数据,输出一行,表示解密后的文字。
Sample Input
Zhofrph wr icxsf2006!
Sample Output
Welcome to fzupc2006!
答案
下面展示 实现代码
。
#include <stdio.h>
#include <string.h>
int main()
{
char str[1000];
while(gets(str))
{
int l = strlen(str);
for(int i = 0; i<l; i++)
{
if(((str[i] <= 'z') && (str[i] > 'c'))||((str[i] <= 'Z') && (str[i] > 'C')))
{
str[i] = str[i] - 3;
}
else if(((str[i] <= 'c') && (str[i] >= 'a'))||((str[i] <= 'C') && (str[i] >= 'A')))
{
str[i] = str[i] + 23;
}
}
puts(str);
}
return 0;
}
本题感悟
本块内容可能来自课本或其他网站,若涉及侵权问题,请联系我进行删除,谢谢大家啦~
本题还蛮简单的,但也不妨碍我WA好多次!!呜呜呜,太不细心了T-T