华为OJ基础篇-字符串加解密

题目描述

1、对输入的字符串进行加解密,并输出。

2加密方法为:

当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a;

当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;

其他字符不做变化。

3、解密方法为加密的逆过程。

char JiaM(char x){
	char result = ' ';
	if (x<='9'&&x>='0'){
		if (x == '9'){ result = '0'; }
		else result =x+1;
		return result;

	}
   else if (x<='z'&&x>='a'){
		if (x == 'z'){ result = 'A'; }
		else result =x-'a'+1+'A';
		return result;
	}
   else if (x >= 'A'&&x <= 'Z'){
	   if (x == 'Z'){ result = 'a'; }
	   else result = x - 'A' + 1 + 'a';
	   return result;
   } else{}
}
char jieMi(char x){
	char result = ' ';
	if (x <= '9'&&x >= '0'){
		if (x == '0'){ result = '9'; }
		else result = x - 1;
		return result;
	}
	else if (x <= 'Z'&&x >= 'A'){
		if (x == 'A'){ result = 'z'; }
		else result = x - 'A' - 1 + 'z';
		return result;
	}
	else if (x >= 'a'&&x <= 'z'){
		if (x == 'a'){ result = 'Z'; }
		else result = x - 'a' - 1 + 'A';
		return result;
	} else{}
}
void HWoj(){
	string a = "ACDZZZZ",b,c;
	int len = a.length();
	char tmp;
	for (int i = 0; i < len; ++i){
		tmp = JiaM(a[i]);
		b.push_back(tmp);
	}
	cout << b << endl;
	for (int i = 0; i < len; ++i){
		tmp = jieMi(b[i]);
		c.push_back(tmp);
	}
	cout << c << endl;
}


你可能感兴趣的:(C++,华为)