zoukankan      html  css  js  c++  java
  • PAT1067 试密码 (20分)——测试点4分析 一个易错点

    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

    分析:

    第一次做的时候,傻傻的用C语言  代码写了老长。今天改进了一下用C++  string类型很好用

    #include<iostream>
    #include<string.h>
    using namespace std;
    int main()
    {
        string rpwd,pwd;
        int N,i=0,k;
        cin>>rpwd>>N;
        getchar();
        while(1)//这里偷懒 借鉴了柳婼大神的,其实也可以while(getlin(cin,pwd)) 等效(已测试) 
        {
            getline(cin,pwd);//这里就排除了密码带空格的情况,不用getline会报错
            if(pwd=="#") break;
            i++;
            if(i<=N){
                if(pwd==rpwd){
                    printf("Welcome in
    ");
                    break;
                }
                else{
                    cout<<"Wrong password: "<<pwd<<endl;
                    if(i==N){  //此条件不加在这里测试点4不通过
                        cout<<"Account locked"<<endl;
                        break;
                    }
                }
            }
            else{
    
                cout<<"Account locked"<<endl;
                break;
    
            }
    
        }
        system("pause");
        return 0;
    }
  • 相关阅读:
    WEB网站类型系统中使用的OFFICE控件
    【架构】原型设计工具一览
    【云计算】mesos+marathon 服务发现、负载均衡、监控告警方案
    【自动部署该怎么做?】
    【OpenStack 虚拟机初始化user-data & Cloud-init】
    【数据可视化 参考资料】
    【RabbitMQ 参考资料】
    【CloudFoundry】架构、设计参考
    【OpenStack项目管理-CPU/内存/存储/网络 配额管理】
    【前端自动化构建 grunt、gulp、webpack】
  • 原文地址:https://www.cnblogs.com/ache/p/12333427.html
Copyright © 2011-2022 走看看