• 1081 检查密码 (15 分)


    1081 检查密码 (15 分)

    本题要求你帮助某网站的用户注册模块写一个密码合法性检查的小功能。该网站要求用户设置的密码必须由不少于6个字符组成,并且只能有英文字母、数字和小数点 .,还必须既有字母也有数字。

    输入格式:

    输入第一行给出一个正整数 N(≤ 100),随后 N 行,每行给出一个用户设置的密码,为不超过 80 个字符的非空字符串,以回车结束。

    输出格式:

    对每个用户的密码,在一行中输出系统反馈信息,分以下5种:

    • 如果密码合法,输出Your password is wan mei.
    • 如果密码太短,不论合法与否,都输出Your password is tai duan le.
    • 如果密码长度合法,但存在不合法字符,则输出Your password is tai luan le.
    • 如果密码长度合法,但只有字母没有数字,则输出Your password needs shu zi.
    • 如果密码长度合法,但只有数字没有字母,则输出Your password needs zi mu.

    输入样例:

    5
    123s
    zheshi.wodepw
    1234.5678
    WanMei23333
    pass*word.6
    

    输出样例:

    Your password is tai duan le.
    Your password needs shu zi.
    Your password needs zi mu.
    Your password is wan mei.
    Your password is tai luan le.
    #include <iostream>
    #include <cmath>
    #include<algorithm>
    #include<map>
    using namespace std;
    int check(string &str)
    {
        int num=0,letter=0;
        for(int i=0;i<str.size();i++)
        {
            if(isalpha(str[i]))
                letter++;
            else if(isdigit(str[i]))
                num++;
            else if(str[i]!='.')
                return -1;
        }
        if(num==0)
            return 0;
        if(letter==0)
            return 1;
        return 2;
    }
    
    
    int main()
    {
        int n;
        cin>>n;
        getchar();
        string temp;
        for(int i=0;i<n;i++)
        {
            getline(cin,temp);
            if(temp.size()<6)
            {
                cout<<"Your password is tai duan le."<<endl;
                continue;
            }
            int num=check(temp);
            if(num==-1)
                cout<<"Your password is tai luan le.
    ";
            else if(num==0)
                cout<<"Your password needs shu zi.
    ";
            else if(num==1)
                cout<<"Your password needs zi mu.
    ";
            else
                cout<<"Your password is wan mei.
    ";
        }
        return 0;
    }
  • 相关阅读:
    悬线法练习
    Codechef MAY 15 Counting on a directed graph
    Codechef MAY 15 Chef and Balanced Strings
    兔子与兔子
    雪花雪花雪花
    约数之和
    分形之城
    递归实现组合型、指数型、排列型 枚举
    最短Hamilton路径
    六十四位整数乘法
  • 原文地址:https://www.cnblogs.com/zhanghaijie/p/10413164.html
Copyright © 2020-2023  润新知