本题要求编写程序,将给定字符串中的大写英文字母按以下对应规则替换:
原字母 对应字母
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 (void){
char s[81];//字符串的定义
gets (s);
int i;
for(i = 0; s[i] != '\0'; i++){
if(s[i] >= 'A' && s[i] <= 'Z'){
s[i] = 'Z' - (s[i] - 'A');//这个字母距离A有多少,换完以后也会距离Z有多少
//参考别人的做法,可以试一下几个字母,但是不容易想到
}
}
puts(s);
return 0;
}
//也要熟悉这一种输入,gets会自动把换行符变为\0
k = 0;
while ( (str[k] = getchar()) != '\n' )
k++;
str[k] = '\0';