有一行电文,已按如下规律译成密码:
A-->Z a-->z
B-->Y b-->y
C-->X c-->x
...... ......
即第一个字母变成第26个字母,第i个字母变成第(26-i+1)个字母,非字母字符不变。要求根据密码译回原文,并输出。
输入样例:
ZYX123zyx
输出样例:
ABC123abc
#include <stdio.h>
#include <string.h>
int main()
{
char str[10]={0};
scanf("%s",str);
for(int i=0;i<strlen(str);i++)
{
if(str[i]>='a'&&str[i]<='z')
str[i]='a'+'a'+25-str[i]; //新旧字符相加值不变为2x+25;
if(str[i]>='A'&&str[i]<='Z')
str[i]='A'+'A'+25-str[i]; //ASCII码:字符对应整数
}
printf("%s",str); //%s可输出相加后的字符
return 0;
}