PAT-B 1033 舊鍵盤打字【字串】

Enjoy_process發表於2019-02-23

                                              PAT-B 1033 舊鍵盤打字

                       https://pintia.cn/problem-sets/994805260223102976/problems/994805288530460672

 

 

題目

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

輸入

輸入在 2 行中分別給出壞掉的那些鍵、以及應該輸入的文字。其中對應英文字母的壞鍵以大寫給出;每段文字是不超過 10​5​​ 個字元的串。可用的字元包括字母 [a-zA-Z]、數字 0-9、以及下劃線 _(代表空格)、,.-+(代表上檔鍵)。題目保證第 2 行輸入的文字串非空。注意:如果上檔鍵壞掉了,那麼大寫的英文字母無法被打出。

輸出

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

樣例輸入

7+IE.
7_This_is_a_test.

樣例輸出

_hs_s_a_tst

分析

簡單題,具體看程式。

C++程式

#include<iostream>
#include<string>

using namespace std;

bool flag[200];//flag[i]=true表示ASCII碼為i的字元不能列印出來 

int main()
{
	string s1,s2;
	getline(cin,s1);
	getline(cin,s2);
	for(int i=0;i<s1.length();i++) 
	{
		if(s1[i]=='+')//上檔鍵壞了 
		{
			for(int i=0;i<26;i++)
			  flag['A'+i]=true;//26個大寫字母不用列印出來 
		}
		else if(isalpha(s1[i]))//s1[i]是大寫字母 
		{
			flag[s1[i]]=true;
			flag[s1[i]+32]=true;//對應的小寫字母也不能列印 
		}
		else
		  flag[s1[i]]=true;
	}
	for(int i=0;i<s2.length();i++)
	  if(!flag[s2[i]])
	    cout<<s2[i];
	cout<<endl;
	return 0;
}

 

相關文章