本题要求编写程序,将给定字符串中的大写英文字母按以下对应规则替换:
原字母 | 对应字母 |
---|---|
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>
#include <ctype.h> //处理字符的头文件
int main ()
{
char ch;int n=0;int a[80],i; //ch用来存储读取的字符,n,i计数,数组用来存储字符的数组形式
ch=getchar();
while(ch!='\n')
{
if(isupper(ch)) //判断是否是大写字母
{
a[n]=155-(int)ch; //将A换为Z,就是65<->90,
} //把与A字符的距离和与Z字符距离相等,'Z'-('字符'-'A')>>155-'字符'
else
{
a[n]=(int)ch; //非大写字符不变
}
ch=getchar();
n++;
}
for(i=0;i<n;i++)
{
printf("%c",a[i]); //遍历数组以字符形式输出
}
return 0;
}