12:加密的病历单
总时间限制: 1000ms 内存限制: 65536kB
描述
小英是药学专业大三的学生,暑假期间获得了去医院药房实习的机会。
在药房实习期间,小英扎实的专业基础获得了医生的一致好评,得知小英在计算概论中取得过好成绩后,主任又额外交给她一项任务,解密抗战时期被加密过的一些伤员的名单。
经过研究,小英发现了如下加密规律(括号中是一个“原文 -> 密文”的例子)
- 原文中所有的字符都在字母表中被循环左移了三个位置(dec -> abz)
- 逆序存储(abcd -> dcba )
- 大小写反转(abXY -> ABxy)
输入
一个加密的字符串。(长度小于50且只包含大小写字母)
输出
输出解密后的字符串。
样例输入
GSOOWFASOq
样例输出
Trvdizrrvj
源码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int main()
{
char a[256];
int i;
cin>>a;//这里注意如果只输入大小写字符才能直接用cin,有空格啥的用cin.getline(a[],size)
int len=strlen(a);//计算字符串长度
for(i=0; i<len; i++) //按规则进行加密
{
if(a[i]>='a'&&a[i]<='z')//小写的情况
{
a[i]+=3;//向右移动3个字符
if(a[i]>122) a[i]-=26;//若为x,y,z,转换为a,b,c
a[i]-=32;//小写转换为大写
}
else if(a[i]>='A'&&a[i]<='Z')//大写的情况
{
a[i]+=3;//向右移动3个字符
if(a[i]>90) a[i]-=26;//若为X,Y,Z,转换为A,B,C
a[i]+=32;//大写转换为小写
}
}
reverse(a,a+len);
cout<<a;
return 0;
}
本文介绍了一种特殊的字符串加密方法,包括字符左移、逆序存储和大小写反转,并提供了一个C++实现示例,用于解密抗战时期的伤员名单。
759

被折叠的 条评论
为什么被折叠?



