本题要求编写程序,将给定字符串中的大写英文字母按以下对应规则替换:
原字母 | 对应字母 |
---|---|
A | Z |
B | Y |
C | X |
D | W |
… | … |
X | C |
Y | B |
Z | A |
输入格式:
输入在一行中给出一个不超过80个字符、并以回车结束的字符串。
输出格式:
输出在一行中给出替换完成后的字符串。
输入样例:
Only the 11 CAPItaL LeTtERS are replaced.
输出样例:
Lnly the 11 XZKRtaO OeGtVIH are replaced.
代码如下:
#include<stdio.h>
int main()
{
char op[80];
int i=0,j;
while((op[i]=getchar())!='\n')
{
i++;
}
for(j=0;j<i;j++)
{
if(op[j]>='A'&&op[j]<='Z')
{
op[j]=155-op[j];
}
}
for(j=0;j<i;j++)
{
printf("%c",op[j]);
}
}
做这个题的最大关键是要明确ASC||码中'A'到‘Z’之间的差是65.
根据这个特点,我们即可进行字符的转换