WERTYU
题目思路
- 从题目可知,对于字符串的每一个元素都有一个对应的字符,我们只需要扫描字符串然后输出这个对应字符就好了
- 下面从题目出发,确定如何定下来这个映射表。一种简单的方式是一一映射,设定一个两行的二维数组,然后进行映射。
- 这里采用的是一个比较简单的方法,根据题目,我们不妨把键盘上的字符按照行写入一位数组,很显然,题目中的映射关系就是 第n个字符映射到第n-1个字符。
- 这里不用纠结边界,因为对于键盘左侧第一列字符,题目是不会输入的,就不会出现错位的情况。对于键盘右侧的一列字符,总是有对应的字符输出
#include<stdio.h>
char *reflection = "`1234567890-=QWERTYUIOP[]\\ASDFGHJKL;'ZXCVBNM,./";
char convert(char c);
int main(){
char c;
int position = 0;
while( (c = getchar())!=EOF ){
printf("%c",convert(c));
}
return 0;
}
char convert(char c){
for(int i = 0; reflection[i]; i++){
if(reflection[i] == c)
return reflection[i-1];
}
return c;
}