*题目描述
1、对输入的字符串进行加解密,并输出。
2加密方法为:
当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a;
当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;
其他字符不做变化。
3、解密方法为加密的逆过程。
接口描述:
实现接口,每个接口实现1个基本操作:
void Encrypt (char aucPassword[], char aucResult[]):在该函数中实现字符串加密并输出
说明:
1、字符串以\0结尾。
2、字符串最长100个字符。
int unEncrypt (char result[], char password[]):在该函数中实现字符串解密并输出
说明:
1、字符串以\0结尾。
2、字符串最长100个字符。*
输入描述:
输入说明
输入一串要加密的密码
输入一串加过密的密码
输出描述:
输出说明
输出加密后的字符
输出解密后的字符
示例1
输入
abcdefg
BCDEFGH
输出
BCDEFGH
abcdefg
#include<stdio.h>
#include<string.h>
void Encrypt (char aucPassword[], char aucResult[])
{
int len = strlen(aucResult);
int i;
for(i = 0; i < len; i++)
{
if(('A' <= aucResult[i] && aucResult[i] < 'Z')
|| ('a' <= aucResult[i] && aucResult[i] < 'z')
|| ('0' <= aucResult[i] && aucResult[i] < 9))
{
if('A' <= aucResult[i] && aucResult[i] < 'Z')
{
aucPassword[i] = aucResult[i] + 33;
}
if('a' <= aucResult[i] && aucResult[i] < 'z')
{
aucPassword[i] = aucResult[i] - 31;
}
if('0' <= aucResult[i] && aucResult[i] < 9)
{
aucPassword[i] = aucResult[i] + 1;
}
if(aucResult[i] == 'z')
{
aucPassword[i] = 'A';
}
if(aucResult[i] == 'Z')
{
aucPassword[i] = 'a';
}
if(aucResult[i] == '9')
{
aucPassword[i] = '0';
}
}
else
{
aucPassword[i] = aucResult[i];
}
printf("%c", aucPassword[i]);
}
printf("\n");
return;
}
int unEncrypt (char result[], char password[])
{
int len = strlen(password);
int i;
for(i = 0; i < len; i++)
{
if(('A' < password[i] && password[i] <= 'Z')
||('a' < password[i] && password[i] <= 'z')
||('0' < password[i] && password[i] <= '9'))
{
if('A' < password[i] && password[i] <= 'Z')
{
result[i] = password[i] + 31;
}
if('a' < password[i] && password[i] <= 'z')
{
result[i] = password[i] - 33;
}
if('0' < password[i] && password[i] <= '9')
{
result[i] = password[i] - 1;
}
if(password[i] == 'A')
{
result[i] = 'z';
}
if(password[i] == 'a')
{
result[i] = 'Z';
}
if(password[i] == '0')
{
result[i] = '9';
}
}
else
{
result[i] = password[i];
}
printf("%c", result[i]);
}
//printf("\n");
return 0;
}
int main()
{
char Arr[102] = {0};
char Arr_Password[102] = {0};
char Arr_Result[102] = {0};
char Arr_return[102] = {0};
while(scanf("%s\n%s", Arr, Arr_return) != EOF)
{
Encrypt(Arr_Password, Arr);
unEncrypt(Arr_Result, Arr_return);
//printf("%s\n", Arr_Password);
//printf("%s\n", Arr_Result);
memset(Arr, 0, 102);
memset(Arr_Password, 0, 102);
memset(Arr_Result, 0, 102);
memset(Arr_return, 0, 102);
}
return 0;
}