12:加密的病历单
1.描述
小英是药学专业大三的学生,暑假期间获得了去医院药房实习的机会。
在药房实习期间,小英扎实的专业基础获得了医生的一致好评,得知小英在计算概论中取得过好成绩后,主任又额外交给她一项任务,解密抗战时期被加密过的一些伤员的名单。
经过研究,小英发现了如下加密规律(括号中是一个“原文 -> 密文”的例子)
1. 原文中所有的字符都在字母表中被循环左移了三个位置(dec -> abz)
2. 逆序存储(abcd -> dcba )
3. 大小写反转(abXY -> ABxy)
2.输入
一个加密的字符串。(长度小于50且只包含大小写字母)
3.输出
输出解密后的字符串。
4.样例输入
GSOOWFASOq
5.样例输出
Trvdizrrvj
6.题意
解密加密后的病例单
7.思路
首先,所有的字符都在字母表中被循环左移三个位置。二,逆序存储。三,大小写反转
8.代码实现
#include<bits/stdc++.h> #include<cstring> using namespace std; int main() { string a; int n=0; cin>>a; for(int i=0;i<a.size();i++){ if('A'<=a[i]&&a[i]<='Z'){ a[i]=a[i]+32;//大写变小写 } else if('a'<=a[i]&&a[i]<='z'){ a[i]=a[i]-32;//小写变大写 } } for(int i=0;i<a.size();i++){ if('a'<=a[i]&&a[i]<='w'){ a[i]=a[i]+3;//(小写)左移3位 } else if('x'<=a[i]&&a[i]<='z'){ a[i]=a[i]-23;//(小写)(特殊情况) 左移3位 } else if('A'<=a[i]&&a[i]<='W'){ a[i]=a[i]+3;//(大写)左移三位 } else if('X'<=a[i]&&a[i]<='Z'){ a[i]=a[i]-23;//(大写)(特殊情况)左移三位 } } for(int i=a.size()-1;i>=0;i--){//逆序存储 cout<<a[i]; } return 0; }
标签:1.7,加密,int,编程,解密,字符串,小英,逆序 From: https://www.cnblogs.com/shi66/p/17181404.html