1029. 信息加密 (Standard IO)
时间限制: 1000 ms 空间限制: 262144 KB 具体限制
题目描述
在传递信息的过程中,为了加密,有时需要按一定规则将文本转换成密文发送出去。有一种加密规则是这样的:
1. 对于字母字符,将其转换成其后的第3个字母。例如:A→D,a→d,X→A,x→a;
2. 对于非字母字符,保持不变。
现在,请你根据输入的一行字符,输出其对应的密码。
输入
输入一个字符串。
输出
输出加密后的字符串。
样例输入
I(2016)love(08)China(15)!
样例输出
L(2016)oryh(08)Fklqd(15)!
数据范围限制
字符串长度不超过100。
问题分析
这个问题是考对ASCII码表和char一维数组的应用。所以,第一个关键是把ASCII码表找出来,跟问题对照一下就知道怎么转换了。大写字母在65-90之间,但是超过87(W)的就要应用不同的处理方式;小写字母在97-122之间,但是119(w)也一样要用不同和处理方式。代码如下:
#include <iostream>
using namespace std;
int main()
{
int i=0;
char a[100]={0},b[100]={0};//字符数组要先初始化,否则输出时可能会出现乱码
gets(a);
while(a[i]!='\0')//判断字符串结尾符号
{
if(a[i]>=65 && a[i]<=90)//大写字母
{
if(a[i]>=88)
b[i] = a[i] - 23;//X,Y,Z
else
b[i] = a[i] + 3;
}
else if(a[i]>=97 && a[i]<=122)//小写字母
{
if(a[i]>=120)
b[i] = a[i] - 23;//x,y,z
else
b[i] = a[i] + 3;
}
else
b[i] = a[i];
i++;
}
printf("%s",b);
return 0;
}