Description
在人类历史上,对信息保护的需求与对信息本身的需求一样久远。第一个用于加密和解密文本的编码方式是凯撒密码。凯撒密码约定的规则是,源文本中每个英文字母都被英文字母表中该字母后第三个位置的字母替换。例如,A->D, B->E, X->A, z->c。所有其他的符号都保持不变。现在请你写一个程序将加密后的文本解密。题目中大小写英文字母表分开,各自形成一个循环表。
Input
本题有多组输入数据,每组数据只有一行,表示加密后的文字,由字母、空格、数字以及各种标点组成,文字长度不超过80个字符。
Output
对于每组数据,输出一行,表示解密后的文字。
Sample Input
Zhofrph wr icxsf2006!
Sample Output
Welcome to fzupc2006!
AC代码如下:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
using namespace std;
int main()
{
char a[100];
int n,i,flag;
while(gets(a))
{
int l=(int)strlen(a);
n=-3;
for(i=0; i<l; i++)
{
if( (a[i]>='a' && a[i]<='z') || (a[i]>='A' && a[i]<='Z') )
{
if(a[i]>=97) flag=0;
else flag=1;
a[i]+=n;
if(flag==0)
{
if(a[i]<97) a[i]+=26;
}
else
{
if(a[i]<65) a[i]+=26;
}
}
}
printf("%s\n",a);
}
return 0;
}