• PAT 1067. 试密码(20)


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

    输入格式:

    输入在第一行给出一个密码(长度不超过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,否则有测试点错误。
    #include<stdio.h>
    #include<string.h>
    int main(){
        char a[30];
        int n;
        int m = 0;
        int k = 0;
        scanf("%s",a);
        scanf("%d",&n);
        char temp[100];
        getchar();
        while(1){
            gets(temp);
            int len = strlen(temp);
            if(len==1&&temp[0]=='#'){
                break;
            }
            if(strcmp(temp,a)==0){
                printf("Welcome in
    "); 
                break;
            }else{
                printf("Wrong password: %s
    ",temp);
                m++;
                if(m==n){
                    printf("Account locked
    ");
                    break;
                }
            }
            
        }
    } 
  • 相关阅读:
    数据结构——霍夫曼树及题目场景应用
    算法——模式匹配
    深入理解Java虚拟机(十)——线程安全与锁优化
    深入理解Java虚拟机(九)——后端编译与优化
    算法——计算点集中共线最多点的直线
    算法——移掉K位数字使得数值最小
    算法—— n个骰子的点数
    Java并发编程的艺术(十二)——并发容器和框架
    算法——不用加减乘除符号运算加法
    5章-项目范围管理-day4
  • 原文地址:https://www.cnblogs.com/lolybj/p/6808622.html
Copyright © 2020-2023  润新知