天天看點

PAT 乙級 1033 舊鍵盤打字 (20分)

1033 舊鍵盤打字 (20分)

舊鍵盤上壞了幾個鍵,于是在敲一段文字的時候,對應的字元就不會出現。現在給出應該輸入的一段文字、以及壞掉的那些鍵,打出的結果文字會是怎樣?

輸入格式:

輸入在 2 行中分别給出壞掉的那些鍵、以及應該輸入的文字。其中對應英文字母的壞鍵以大寫給出;每段文字是不超過 10

​5

​​ 個字元的串。可用的字元包括字母 [a-z, A-Z]、數字 0-9、以及下劃線 _(代表空格)、,、.、-、+(代表上檔鍵)。題目保證第 2 行輸入的文字串非空。

注意:如果上檔鍵壞掉了,那麼大寫的英文字母無法被打出。

輸出格式:

在一行中輸出能夠被打出的結果文字。如果沒有一個字元能被打出,則輸出空行。

輸入樣例:

7+IE.

7_This_is_a_test.

輸出樣例:

#include <iostream>
using namespace std;
int main(){
    string error_key,input,output;
    bool flag = false;
    output = "";
    getline(cin,error_key);//這裡必須用getline,否則中間有個測試點會過不去,因cin讀取無法處理空格,不能讀完一整行
    getline(cin,input);
    for(int i = 0; i < error_key.length(); i++){
        if(error_key[i] <= 90 && error_key[i] >= 65)
            error_key += char(int(error_key[i]) + 32);
        if(error_key[i] == '+')
            flag  = true;
    }
    for (int i = 0; i < input.length() ; ++i) {
        if(flag && input[i]<= 90 && input[i] >= 65)
            continue;
        if(error_key.find(input[i]) > input.length())
            output += input[i];
    }
    cout<<output<<endl;
    return 0;
}