题目描述:
把手放在键盘上时,稍不注意就会往右错一
位。这样,输入Q会变成输入W,输入J会变成输入K等。键盘如图3-2所示。
输入一个错位后敲出的字符串(所有字母均
大写),输出打字员本来想打出的句子。输入保
证合法,即一定是错位之后的字符串。例如输入中不会出现大写字母A。
样例输入:
O S, GOMR YPFSU/
样例输出:
I AM FINE TODAY.
代码:
#include<stdio.h>
char s[] = "`1234567890-=QWERTYUIOP[]\\ASDFGHJKL;'ZXCVBNM,./";
int main()
{
int i, c;
while((c = getchar()) != EOF)
{
for (i=1; s[i] && s[i]!=c; i++); //找错位之后的字符在常量表中的位置
if (s[i]) putchar(s[i-1]); //如果找到,则输出它的前一个字符
else putchar(c);
}
return 0;
}
总结:
for (i=1; s[i] && s[i]!=c; i++); //一旦在s[]里面找到和c相同的或者到最终也找不到那就退出循环。退出循环时,s[i]要么是和c相同的,要么是空
善用常量数组往往能简化代码。定义常量数组时无须指明大小,编译器会
计算。