當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。
輸入格式:
輸入在第一行給出乙個密碼(長度不超過 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
輸入分析
輸入正確密碼和允許嘗試的次數n
一旦等於n就不能輸入了
輸入可能有空格
主要思路
利用字串比較
依次比較輸入的密碼是否正確,當輸入次數=n,則輸出上鎖
完整**
#include
using
namespace std;
intmain()
else
if(t>=n)
}return0;
}
注意事項
注意輸入可能有空格,所以用getline,但此時要在前面加個getchar,
另外直接輸入#則結束
字串與單個字元比較時,該字元用雙引號
1067 試密碼(20 分)
1067 試密碼 20 分 當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。輸入在第一行給出乙個密碼 長度不超過 20 的 不包含空格 tab 回車的非空字串 和乙個正整數 n 10 分別是正確的密碼和系統允許嘗試的次數。...
1067 試密碼(20 分)
1067 試密碼 20 分 當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。輸入在第一行給出乙個密碼 長度不超過 20 的 不包含空格 tab 回車的非空字串 和乙個正整數 n 10 分別是正確的密碼和系統允許嘗試的次數。...
1067 試密碼 (20 分)
1067 試密碼 20 分 當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。輸入在第一行給出乙個密碼 長度不超過 20 的 不包含空格 tab 回車的非空字串 和乙個正整數 n 10 分別是正確的密碼和系統允許嘗試的次數。...