1067 试密码

一.问题:

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

输入格式:

输入在第一行给出一个密码(长度不超过 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

二思路:

分析:
结束程序只有两种方法:
①输入的串为"#";

②在尝试次数内输入正确的密码。
如果在尝试次数内不能输入正确的密码,账户锁住,但不结束程序,仍然可以输入密码,直到输入"#"为止。

注意:

①这里我一开始以为是,用户一次性输入完多行密码后,程序也一次性输出多行对应结果语句,所以一直做不出来,看来别人的代码后才知道,原来是用户输入一行,程序就输出一行语句,该死的,示例坑人啊

②还有就是用户输入密码时要用gets()函数,用scanf()测试点2,5过不了,目前还不知道为什么,程序不是说了密码是不包含空格、Tab、回车的非空字符串,有点懵。

三.代码实现:

cpp 复制代码
#include<stdio.h>
#include<string.h>

int main()
{
    char password[50] = {'\0'};
    int times = 0;
    scanf("%s %d",password,&times);
    getchar();
    char user_key[50] = {'\0'};
    while(1)
    {
        gets(user_key);
        if(strcmp(user_key,"#") == 0)//用户输入"#",则结束输入
        {
            break;
        }
        if(strcmp(user_key,password) == 0 && times > 0)//用户输入密码正确,且在允许次数范围
                                                        //内,输出提示语句,结束输入
        {
            printf("Welcome in\n");
            break;
        }
        else if(strcmp(user_key,password) != 0 && times > 0)
        {
            //用户输入密码不正确,且在允许次数范围内,输出提示语句
            printf("Wrong password: %s\n",user_key);
            times--;//输入次数减1
            if(times == 0)//次数用完,锁定,结束判断,但此时还可以输入
            {
                printf("Account locked\n");
                times--;
//输入次数减1,此时time < 0,后面不管怎么输入都不会输出提示语了,输入 "#",时则直接结束输入
            }
        }
    }
    return 0;
}
相关推荐
iAkuya4 分钟前
(leetcode)力扣100 62N皇后问题 (普通回溯(使用set存储),位运算回溯)
算法·leetcode·职场和发展
近津薪荼4 分钟前
dfs专题5——(二叉搜索树中第 K 小的元素)
c++·学习·算法·深度优先
xiaoye-duck6 分钟前
吃透 C++ STL list:从基础使用到特性对比,解锁链表容器高效用法
c++·算法·stl
松☆9 分钟前
CANN与大模型推理:在边缘端高效运行7B参数语言模型的实践指南
人工智能·算法·语言模型
java干货19 分钟前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
_F_y20 分钟前
C语言重点知识总结(含KMP详细讲解)
c语言·开发语言
皮皮哎哟27 分钟前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒36 分钟前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝
vortex51 小时前
几种 dump hash 方式对比分析
算法·哈希算法
郝学胜-神的一滴1 小时前
深入解析C/S模型下的TCP通信流程:从握手到挥手的技术之旅
linux·服务器·c语言·网络·网络协议·tcp/ip