题目描述
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
本题考查知识点:字符串、查表法
本题难度:初级
int Encrypt (char password[], char result[])
{
/* 代码在这里实现 */
int len = strlen(password);
for(int i = 0;i<len;i++)
{
if(password[i]>='a'&&password[i]<='z')
{
if(password[i] != 'z')
{
result[i] = password[i]+1-32;
}
else
{
result[i] = 'A';//没有判断
}
}
else if(password[i]>='A'&&password[i]<='Z')
{
if(password[i] != 'Z')
{
result[i] = password[i]+1+32;
}
else
{
result[i] = 'a';//判断错误
}
}
else if(password[i]>='0'&&password[i]<='9')
{
if(password[i] != '9')
{
result[i] = password[i]+1;
}
else
result[i] = '0';
}
else
{
result[i] = password[i];//没有判断
}
}
result[len] = '\0';
return 0;
}
int unEncrypt (char result[], char password[])
{
/* 代码在这里实现 */
int len = strlen(result);
for(int i = 0;i<len;i++)
{
if(result[i]>='a'&&result[i]<='z')
{
if(result[i] != 'a')
{
password[i] = result[i]-1-32;
}
else
{
password[i] = 'Z';//判断错误
}
}
else if(result[i]>='A'&&result[i]<='Z')
{
if(result[i] != 'A')
{
password[i] = result[i]-1+32;
}
else
{
password[i] = 'z';
}
}
else if(result[i]>='0'&&result[i]<='9')
{
if(result[i] != '0')
{
password[i] = result[i]-1;
}
else
password[i] = '9';
}
else
{
password[i] = result[i];//没有判断
}
}
password[len] = '\0';
return 0;
}
优秀代码学习:
int Encrypt (char password[], char result[])
{
char bigletter[] = {"ABCDEFGHIJKLMNOPQRSTUVWXYZA"};
char littleletter[] = {"abcdefghijklmnopqrstuvwxyza"};
char num[] = "01234567890";
if(NULL == password || NULL == result)
{
return -1;
}
for(int i = 0;i < strlen(password);i++)
{
result[i] = password[i];
for(int j = 0;j < 27;j++)
{
if(password[i] == bigletter[j])
{
result[i] = littleletter[j + 1];
break;
}
else if(password[i] == littleletter[j])
{
result[i] = bigletter[j + 1];
break;
}
else if(password[i] == num[j])
{
result[i] = num[j + 1];
break;
}
}
}
result[strlen(password)] = '\0';
return 0;
}
int unEncrypt (char result[], char password[])
{
char bigletter[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZA";
char littleletter[] = "abcdefghijklmnopqrstuvwxyza";
char num[] = "01234567890";
if(NULL == password || NULL == result)
{
return -1;
}
for(int i = 0;i < strlen(result);i++)
{
password[i] = result[i];
for(int j = 26;j >= 0;j--)
{
if(result[i] == bigletter[j])
{
password[i] = littleletter[j - 1];
break;
}
else if(result[i] == littleletter[j])
{
password[i] = bigletter[j - 1];
break;
}
else if(result[i] == num[j])
{
password[i] = num[j - 1];
break;
}
}
}
password[strlen(result)] = '\0';
return 0;
}