有一行电文,已按下面规律译成密码:
A →Z B→Y C→X ……
a→z b→y c→x ……
即第一个字母变成第26个字母,第i个字母变成第(26-i+1)个字母,非字母字符不变。
要求编程序将密码译回原文,并输出密码和原文。
第一种
利用循环分别记录两组大写和小写符号,在用位数差赋值
#include
#include
int main()
{
char cl[26], sl[26], p[20];
int i, j, k;
for (i=0, j='A', k='a'; i<26; cl[i]=j++, sl[i]=k++, i++);
printf("Please enter password: ");
gets(p);
printf("密码: ");
puts(p);
for (i=0; i<20; i++)
for (j=0; j<26; j++){
if (p[i]==cl[j]){
p[i]=cl[25-j]; break;
}
if (p[i]==sl[j]){
p[i]=sl[25-j]; break;
}
}
printf("原文: ");
puts(p);
return 0;
}
第二种
利用ASCII码的10进制位数值,规律为(最小的字母A(65)和最大的字母Z(90)之和减去当时的string[i],即是可得)
#include
#include
int main() {
char string[20];
int i;
gets(string);
printf("\密码:\n");
puts(string);
for (i = 0; i < 20; i++) {
if (string[i] >= 'a' && string[i] <= 'z')
string[i]=97+122-string[i];//用ASCII码,97是a的10进制值,122是z的
if (string[i] >= 'A' && string[i] <= 'Z')
string[i]=65+90-string[i];//65是A,90是Z
}
printf("\原文:\n");
puts(string);
return 0;
}