题目大意:
在情报传递过程中,为了防止情报被截获,往往需要对情报用一定的方式加密,简单的加密算法虽然不足以完全避免情报被破译,但仍然能防止情报被轻易的识别。我们给出一种最简的的加密方法,对给定的一个字符串,把其中从a-y,A-Y的字母用其后继字母替代,把z和Z用a和A替代,其他非字母字符不变,则可得到一个简单的加密字符串。
样例输入:
输入一行,包含一个字符串,长度小于80个字符。
Hello! How are you!
样例输出:
输出每行字符串的加密字符串。
Ifmmp! Ipx bsf zpv!
限制条件:
Time Limit: 1000 ms Memory Limit: 65536 kb
我个人认为,本题出得还是比较好的,考察了两方面的内容:1.字符数组的运用熟练程度 2.对于for循环的理解和运用。本题还是比较简单的,只要先特判一下A,Z,a,z,再使用阿斯克码+1,输出就好了。
小提示:现在听说字符数组输入的gets不让用了,说会导致电脑什么东西泄露,所以在以后的代码中,我会尽量使用cin.getline( , ),不要过于疑惑。
#include<bits/stdc++.h>
using namespace std;
char a[105];
int main()
{
cin.getline(a,105);
int l=strlen(a);
for (int i=0;i<l;i++)
{
if((a[i]>='a'&&a[i]<='z')||(a[i]>='A'&&a[i]<='Z'))
if((a[i]>='a'&&a[i]<='y')||(a[i]>='A'&&a[i]<='Y'))
cout<<char(a[i]+1);
else if(a[i]=='z')
cout<<'a';
else
cout<<'A';
else
cout<<a[i];
}
return 0;
}
作者初出茅庐,可能有可以改进的地方,请在评论区提出,不喜勿喷,蟹蟹。