1067-试密码
leenickzh Lv4

当你试图登录某个系统却忘了密码时,系统一般只会允许你尝试有限多次,当超出允许次数时,账号就会被锁死.本题就请你实现这个小功能.

输入格式

输入在第一行给出一个密码(长度不超过 20 的,不包含空格,Tab,回车的非空字符串)和一个正整数 N(<= 10),分别是正确的密码和系统允许尝试的次数.随后每行给出一个以回车结束的非空字符串,是用户尝试输入的密码.输入保证至少有一次尝试.当读到一行只有单个 # 字符时,输入结束,并且这一行不是用户的输入.

输出格式

对用户的每个输入,如果是正确的密码且尝试次数不超过 N,则在一行中输出 Welcome in,并结束程序;如果是错误的,则在一行中按格式输出 Wrong password: 用户输入的错误密码;当错误尝试达到 N 次时,再输出一行 Account locked,并结束程序.

输入样例 1

1
2
3
4
5
6
Correct%pw 3
correct%pw
Correct@PW
whatisthepassword!
Correct%pw
#

输出样例 1

1
2
3
4
Wrong password: correct%pw
Wrong password: Correct@PW
Wrong password: whatisthepassword!
Account locked

输入样例 2

1
2
3
4
5
6
cool@gplt 3
coolman@gplt
coollady@gplt
cool@gplt
try again
#

输出样例 2

1
2
3
Wrong password: coolman@gplt
Wrong password: coollady@gplt
Welcome in

分析

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#include <iostream>
#include <string>
#include <vector>
using namespace std;

int main()
{
vector<string> pwds;
string correctPwd;
int lockCount, failCount = 0;
cin >> correctPwd >> lockCount;
string str;
getchar();
while (getline(cin, str))
{
if (str.compare("#") == 0)
{
break;
}
pwds.push_back(str);
}
for (int i = 0; i < pwds.size(); i++)
{
if (correctPwd.compare(pwds[i]) == 0 && failCount <= lockCount)
{
cout << "Welcome in" << endl;
return 0;
}
else
{
cout << "Wrong password: " << pwds[i] << endl;
failCount++;
if (failCount >= lockCount)
{
cout << "Account locked" << endl;
return 0;
}
}
}
return 0;
}
  • Post title:1067-试密码
  • Post author:leenickzh
  • Create time:2021-09-05 20:15:33
  • Post link:https://nickk.cn/2021/09/05/1067-试密码/
  • Copyright Notice:All articles in this blog are licensed under BY-NC-SA unless stating additionally.
 Comments