旧键盘打字 -- PAT乙级1033

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

输入格式
输入在 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;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章