描述
舊鍵盤上壞了幾個鍵,於是在敲一段文字的時候,對應的字符就不會出現。現在給出應該輸入的一段文字、以及壞掉的那些鍵,打出的結果文字會是怎樣?
輸入格式
輸入在 2 行中分別給出壞掉的那些鍵、以及應該輸入的文字。其中對應英文字母的壞鍵以大寫給出;每段文字是不超過 10^5個字符的串。可用的字符包括字母 [a-z, A-Z]、數字 0-9、以及下劃線 _(代表空格)、,、.、-、+(代表上檔鍵)。題目保證第 2 行輸入的文字串非空。
注意:如果上檔鍵壞掉了,那麼大寫的英文字母無法被打出。
輸入樣例
7+IE.
7_This_is_a_test.
輸出樣式
_hs_s_a_tst
解題思路
題目不難,判斷每一個字符即可~,但是有個坑爹的就是一種情況, 那就是鍵盤是好的,此時就第一行輸入就爲空,本人因爲這裏卡住近半小時~~~
#include <iostream>
#include <string>
using namespace std;
string bad,in;
int main()
{
getline(cin, bad);
cin >> in;
bool up = false;
bool isCount = true;
for(int i = 0 ; i < bad.length(); i++)
{
if(bad[i] == '+') up = true;
}
for(int i = 0 ;i < in.length(); i++){
bool flag = true;
if(up){
if(in[i] >= 'A' && in[i] <= 'Z'){
continue;
}
}
for(int j = 0; j < bad.length(); j++){
if(in[i] >= 'a' && in[i] <= 'z'){
if(bad[j] == in[i] || bad[j] + 32 == in[i]) {
flag = false;
break;
}
}else{
if(bad[j] == in[i]) {
flag = false;
break;
}
}
}
if(flag){
isCount = false;
cout << in[i];
}
}
if(isCount){
cout << endl;
}
return 0;
}