1067 試密碼(20 分)

2021-08-21 17:46:47 字數 1240 閱讀 2735

1067 試密碼(20 分)

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

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

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

correct%pw 3

correct%pw

correct@pw

whatisthepassword!

correct%pw

#

wrong password: correct%pw

wrong password: correct@pw

wrong password: whatisthepassword!

account locked

cool@gplt 3

coolman@gplt

coollady@gplt

cool@gplt

try again

#

wrong password: coolman@gplt

wrong password: coollady@gplt

welcome in

解題思路:本題要求輸入的資料以『#』結束,所以用while迴圈,以『#』結束,每輸入一行字串(注意輸入的字串可能有空格,所以用getline(cin,a)),就讓其和密碼密碼比較,把三種情況輸出即可。

**如下:

#include#includeusing namespace std;

const int n=20;

string a;

string b;

int main()

i++;

} return 0;

}

1067 試密碼(20 分)

1067 試密碼 20 分 當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。輸入在第一行給出乙個密碼 長度不超過 20 的 不包含空格 tab 回車的非空字串 和乙個正整數 n 10 分別是正確的密碼和系統允許嘗試的次數。...

1067 試密碼 (20 分)

1067 試密碼 20 分 當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。輸入在第一行給出乙個密碼 長度不超過 20 的 不包含空格 tab 回車的非空字串 和乙個正整數 n 10 分別是正確的密碼和系統允許嘗試的次數。...

1067 試密碼 (20 分)

1067 試密碼 20 分 當你試圖登入某個系統卻忘了密碼時,系統一般只會允許你嘗試有限多次,當超出允許次數時,賬號就會被鎖死。本題就請你實現這個小功能。輸入在第一行給出乙個密碼 長度不超過 20 的 不包含空格 tab 回車的非空字串 和乙個正整數 n 10 分別是正確的密碼和系統允許嘗試的次數。...