12:加密的病历单
查看提交统计提问
总时间限制: 1000ms 内存限制: 65536kB
描述
小英是药学专业大三的学生,暑假期间获得了去医院药房实习的机会。
在药房实习期间,小英扎实的专业基础获得了医生的一致好评,得知小英在计算概论中取得过好成绩后,主任又额外交给她一项任务,解密抗战时期被加密过的一些伤员的名单。
经过研究,小英发现了如下加密规律(括号中是一个“原文 -> 密文”的例子)
1. 原文中所有的字符都在字母表中被循环左移了三个位置(dec -> abz)
2. 逆序存储(abcd -> dcba )
3. 大小写反转(abXY -> ABxy)
输入
一个加密的字符串。(长度小于50且只包含大小写字母)
输出
输出解密后的字符串。
样例输入
GSOOWFASOq
样例输出
Trvdizrrvj
#include<stdio.h>
#include<string.h>
int main()
{
void fun(char ch[], int len);
char ch[50];
int len;
gets(ch);
len=strlen(ch);
fun(ch,len);
printf("%s", ch);
return 0;
}
void fun(char ch[], int len)
{
int i;
char c;
char *p=ch;
while(*p!='\0')
{
if(*p>='A'&&*p<='Z') *p=*p+32;
else *p=*p-32;
p++;
}
for(i=0;i<=(len-1)/2;i++)
{
c=ch[i];
ch[i]=ch[len-1-i];
ch[len-1-i]=c;
}
p=ch;
while(*p!='\0')
{
if(*p=='X'||*p=='Y'||*p=='Z'||*p=='x'||*p=='y'||*p=='z') *p=*p+3-26;
else *p=*p+3;
p++;
}
}