测试链接
总时间限制: 1000ms 内存限制: 65536kB
描述
小英是药学专业大三的学生,暑假期间获得了去医院药房实习的机会。
在药房实习期间,小英扎实的专业基础获得了医生的一致好评,得知小英在计算概论中取得过好成绩后,主任又额外交给她一项任务,解密抗战时期被加密过的一些伤员的名单。
经过研究,小英发现了如下加密规律(括号中是一个“原文 -> 密文”的例子)
- 原文中所有的字符都在字母表中被循环左移了三个位置(dec -> abz)
- 逆序存储(abcd -> dcba )
- 大小写反转(abXY -> ABxy)
输入
一个加密的字符串。(长度小于50且只包含大小写字母)
输出
输出解密后的字符串。
样例输入
GSOOWFASOq
样例输出
Trvdizrrvj
#include<iostream>
#include<cstring>
using namespace std;
char s[256];
int main()
{
int i,len;
char temp;
gets(s);
len=strlen(s);
for(i=0;i<len;i++)
{
temp=s[i];
if ((s[i]>='a' && s[i]<='w') || (s[i]>='A' && s[i]<='W'))
temp+=3;
if ((s[i]>='x' && s[i]<='z') || (s[i]>='X' && s[i]<='Z'))
temp-=23;
if (s[i]>='a' && s[i]<='z')
temp-=32;
if (s[i]>='A' && s[i]<='Z')
temp+=32;
s[i]=temp;
}
for (i=len-1;i>=0;i--)
cout<<s[i];
return 0;
}