適合初步練習PAT乙級 (1067) 試密碼

2021-10-02 15:29:53 字數 1190 閱讀 5861

當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。

輸入格式:

輸入在第一行給出乙個密碼(長度不超過 20 的、不包含空格、tab、回車的非空字串)和乙個正整數 n(≤ 10),分別是正確的密碼和系統允許嘗試的次數。隨後每行給出乙個以回車結束的非空字串,是使用者嘗試輸入的密碼。輸入保證至少有一次嘗試。當讀到一行只有單個 # 字元時,輸入結束,並且這一行不是使用者的輸入。

輸出格式:

對使用者的每個輸入,如果是正確的密碼且嘗試次數不超過 n,則在一行中輸出 welcome in,並結束程式;如果是錯誤的,則在一行中按格式輸出 wrong password: 使用者輸入的錯誤密碼;當錯誤嘗試達到 n 次時,再輸出一行 account locked,並結束程式。

輸入樣例 1:

correct%pw 3

correct%pw

correct@pw

whatisthepassword!

correct%pw

輸出樣例 1:

wrong password: correct%pw

wrong password: correct@pw

wrong password: whatisthepassword!

account locked

輸入樣例 2:

cool@gplt 3

coolman@gplt

coollady@gplt

cool@gplt

try again

輸出樣例 2:

wrong password: coolman@gplt

wrong password: coollady@gplt

welcome in

#include

#include

using

namespace std;

intmain()

else

if(cnt <= n && temp != password)}}

return0;

}

思路:如果已經是」#「就結束while。如果密碼錯誤並且達到嘗試的次數,先輸出wrong password然後輸出account locked。

getchar()的作用為**\n回車,那是輸入數字的時候唯讀了數字沒有讀回車的緣故。

適合初步練習PAT乙級 (1019) 數字黑洞

給定任乙個各位數字不完全相同的 4 位正整數,如果我們先把 4 個數字按非遞增排序,再按非遞減排序,然後用第 1 個數字減第 2 個數字,將得到乙個新的數字。一直重複這樣做,我們很快會停在有 數字黑洞 之稱的 6174,這個神奇的數字也叫 kaprekar 常數。例如,我們從6767開始,將得到 7...

適合初步練習PAT乙級 (1064) 朋友數

如果兩個整數各位數字的和是一樣的,則被稱為是 朋友數 而那個公共的和就是它們的 朋友證號 例如 123 和 51 就是朋友數,因為 1 2 3 5 1 6,而 6 就是它們的朋友證號。給定一些整數,要求你統計一下它們中有多少個不同的朋友證號。輸入格式 輸入第一行給出正整數 n。隨後一行給出 n 個正...

適合初步練習PAT乙級 (1015) 德才論

宋代史學家司馬光在 資治通鑑 中有一段著名的 德才論 是故才德全盡謂之聖人,才德兼亡謂之愚人,德勝才謂之君子,才勝德謂之小人。凡取人之術,苟不得聖人,君子而與之,與其得小人,不若得愚人。現給出一批考生的德才分數,請根據司馬光的理論給出錄取排名。輸入格式 輸入第一行給出 3 個正整數,分別為 n 10...