本题要求编写程序,将给定字符串中的大写英文字母按以下对应规则替换:
| 原字母 | 对应字母 |
|---|---|
| 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.
only the 11 CAPItaL LeTtERS are replaced.
Lnly the 11 XZKRtaO OeGtVIH are replaced.
解题方法一:
#include#include int main(){ char str1[13]={'A','B','C','D','E','F','G','H','I','J','K','L','M'}; char str2[13]={'Z','Y','X','W','V','U','T','S','R','Q','P','O','N'}; char ch[81]; int i,j; gets(ch); for(i=0;i ='A'&&ch[i]<='M'){ for(j=0;j<=12;j++){ if(str1[j]==ch[i]) ch[i]=str2[j]; } } else if(ch[i]>='N'&&ch[i]<='Z'){ for(j=0;j<=12;j++){ if(str2[j]==ch[i]) ch[i]=str1[j]; } } } puts(ch); return 0; }
解题方法二:
#include#include int main(){ char ch[81]; gets(ch); int i; for(i=0;i ='A'&&ch[i]<='Z'){ ch[i]='A'+'Z'-ch[i]; } } puts(ch); return 0; }
总结:
1、定义存放输入字符的数组时,根据题目要求,定义的数组的大小一定要大于80,否则会出现运行时错误;
2、字符串输入函数gets(s); 参数s是字符数组名。函数从输入得到一个字符串,遇到回车输入结束,自动将输入的数据和' '送入数组中。采用gets()输入的字符串允许带空格。
3、字符串输出函数puts(s); 参数s可以是字符数组名或字符串常量。输出时遇到' '自动将其转换为'n',即输出字符串后换行。



