题目描述
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;
}