CCF 1029信息加密

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;
}

猜你喜欢

转载自blog.csdn.net/tainys/article/details/85222670