1067 試密碼 20分 主要思路 測試點解決

2021-10-18 04:18:07 字數 1282 閱讀 5492

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

輸入格式:

輸入在第一行給出乙個密碼(長度不超過 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 分別是正確的密碼和系統允許嘗試的次數。...