Contents
  1. 1. 输入格式:
  2. 2. 输出格式:
  3. 3. 输入样例:
  4. 4. 输出样例:
  5. 5. 分析:
  6. 6. 代码:

旧键盘上坏了几个键,于是在敲一段文字的时候,对应的字符就不会出现。现在给出应该输入的一段文字、以及坏掉的那些键,打出的结果文字会是怎样?

输入格式:

输入在 2 行中分别给出坏掉的那些键、以及应该输入的文字。其中对应英文字母的坏键以大写给出;每段文字是不超过 105 个字符的串。可用的字符包括字母 [a-z, A-Z]、数字 0-9、以及下划线 _(代表空格)、,.-+(代表上档键)。题目保证第 2 行输入的文字串非空。

注意:如果上档键坏掉了,那么大写的英文字母无法被打出。

输出格式:

在一行中输出能够被打出的结果文字。如果没有一个字符能被打出,则输出空行。

输入样例:

7+IE.
7_This_is_a_test.

输出样例:

_hs_s_a_tst

分析:

s1.find(s2[i]) != string::npos表示s1中包含s2[i]字符。本题需要注意的是,第一行字符串可能为空,故一定要用getline输入,而不能用cin >> s1 >> s2 。

代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
#include<iostream>
using namespace std;
int main(){
string s1,s2;
getline(cin,s1);
getline(cin,s2);
for (int i=0;i<s2.size();i++){
if ( s1.find(toupper(s2[i])) != string::npos) continue;
if ( s1.find('+') != string::npos && (s2[i]>='A' && s2[i]<='Z') ) continue;
cout << s2[i];
}
return 0;
}
Contents
  1. 1. 输入格式:
  2. 2. 输出格式:
  3. 3. 输入样例:
  4. 4. 输出样例:
  5. 5. 分析:
  6. 6. 代码: