PAT乙級1033 舊鍵盤打字 20

2021-07-28 14:54:11 字數 1512 閱讀 9231

這題目我已開始用10+26+5鍵盤的方式寫,但是第2個和第4個測試點一直過不掉

很煩,考慮到了第一行有可能為空的情況,但依然不行

只好求助隔壁論壇 唐衣可俊兄的文章,發現他的解法優美極了

tangyikejun

出處:自己修改了他的**,一開始最後的乙個測試點一直a不過,後來才突然發現a~z的判斷很特殊的問題,不僅要考慮上檔鍵

貼出修改後的原始碼

#include #include #include using namespace std;

bool brokenkey[128]; //ascii表上的字元

char s[10005];//錯字行,第一行

int main()

else

} char c = 0;

while(scanf("%c",&c) != eof) else if(wrongkey[i] >= 'a' && wrongkey[i] <= 'z' ) else if(wrongkey[i] >= 'a' && wrongkey[i] <= 'z' ) else if(wrongkey[i] == ',') else if(wrongkey[i] == '.') else if(wrongkey[i] == '-') else if(wrongkey[i] == '_') else if(wrongkey[i] == '+')

} cachelen = strlen(rightkey);

int cnt = 0;

for(int i = 0 ; i < cachelen ; ++i)

else if(rightkey[i] <= 'a' && rightkey[i] >= 'z' ) {

cnt++;

if (!keyenum[rightkey[i]-'a'+10] ) cout<= '0' ) {

cnt++;

if (!keyenum[rightkey[i]-'0'] ) cout<= 'a' && rightkey[i] <= 'z' ) {

cnt++;

if (!keyenum[rightkey[i]-'a'+10] ) cout<

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

輸入格式:

輸入在2行中分別給出壞掉的那些鍵、以及應該輸入的文字。其中對應英文本母的壞鍵以大寫給出;每段文字是不超過105個字元的串。可用的字元包括字母[a-z, a-z]、數字0-9、以及下劃線「_」(代表空格)、「,」、「.」、「-」、「+」(代表上檔鍵)。題目保證第2行輸入的文字串非空。

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

輸出格式:

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

輸入樣例:7+ie.

7_this_is_a_test.

輸出樣例:
_hs_s_a_tst

PAT 乙級 1033 舊鍵盤打字

舊鍵盤上壞了幾個鍵,於是在敲一段文字的時候,對應的字元就不會出現。現在給出應該輸入的一段文字 以及壞掉的那些鍵,打出的結果文字會是怎樣?輸入格式 輸入在2行中分別給出壞掉的那些鍵 以及應該輸入的文字。其中對應英文本母的壞鍵以大寫給出 每段文字是不超過105個字元的串。可用的字元包括字母 a z,a ...

PAT乙級1033舊鍵盤打字

雖然本題沒啥難度,但是有幾個注意點 1.預處理字元1,判斷是否存在 2.再次處理,由於字母只有大寫形式,只要出現大寫字母,就將其bool陣列中的該字母大小寫都設為true 3.出現小寫字母直接用bool陣列判斷即可,大寫字母判斷 是否存在以及bool陣列 4.其他字元,遍歷字元1,若不存在直接輸出即...

舊鍵盤打字 PAT乙級1033

描述 舊鍵盤上壞了幾個鍵,於是在敲一段文字的時候,對應的字元就不會出現。現在給出應該輸入的一段文字 以及壞掉的那些鍵,打出的結果文字會是怎樣?輸入格式 輸入在 2 行中分別給出壞掉的那些鍵 以及應該輸入的文字。其中對應英文本母的壞鍵以大寫給出 每段文字是不超過 10 5個字元的串。可用的字元包括字母...