算法竞赛入门经典WERTYU

题目:

把手放在键盘上时,稍不注意就会往右错一位。这样,输入Q会变成输入W,输入J会变成输入K等。输入一个错位后敲出的字符串(所有字母均大写),输出打字员本来想打出的句子。输入保证合法,即一定是错位之后的字符串。例如输入中不会出现大写字母A。

样例输入:

O S,GOMR YPFSU/

样例输出:

I AM FINE TODAY.

代码:

#include "iostream"
#include "cstdio"
using namespace std;
char a[] = "`1234567890-=QWERTYUIOP[]\\ASDFGHJKL;'ZXCVBNM,./";

int main(){
    int i,c;
    while ((c = getchar())!=EOF){
        for(i = 1; a[i];i++){
            if(c == a[i]){
                break; // 在字符串中寻找c 如果相等就保留下标,在下面处理
            }     
        }
        if(a[i]){
            cout << a[i-1] ; // 找到输出前一个
        }
        else{
            cout << c ;
        }
    }
    return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_37866486/article/details/81388599