本题要求编写程序,将给定字符串中的大写英文字母按以下对应规则替换:
原字母 | 对应字母 |
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.
基本思路:1、ASCII码中‘A'=65,'Z'=90,将输入字符与'A'的距离变为与'Z'的距离,不使用数组
即ch=90-(ch-65)
#include <stdio.h>
int main()
{
char ch;
while((getchar())!='\n'){ ///输入字符串
if(ch>=65&&ch<=90)
ch=90-(ch-65);
putchar(ch);
}
return 0;
}
2、不知ASCII码值,用字符常量代替,发现所给替换原则中左右两边ASCII码值之和固定
#include <stdio.h>
int main()
{
char s[10000];
gets(s);
int i;
for(i=0;s[i]!=0;i++){ //遍历字符数组
if(s[i]>='A'&&s[i]<='Z')
s[i]='A'+'Z'-s[i]; //s[i]='A'-(s[i]-'Z')
}
for(i=0;s[i]!=0;i++)
printf("%c",s[i]);
return 0;
}