• 设计密码


    网上流传一句话:“常在网上飘啊,哪能不挨刀啊”。其实要想能安安心心地上网其实也不难,学点安全知识就可以。 首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件: (1)密码长度大于等于8,且不要超过16。 (2)密码中的字符应该来自下面“字符类别”中四组中的至少三组。  大写字母:A,B,C...Z  小写字母:a,b,c...z  数字: 0,1,2...9  特殊符号:~, !, @ , #, $, %, ^ 给你一个密码,你的任务就是判断它是不是一个安全的密码。

    输入

    输入数据第一行包含一个数M,接下有M行,每行一个密码(长度最大可能为50),密码仅包括上面的四类字符。

    输出

    对于每个测试实例,判断这个密码是不是一个安全的密码,是的话输出YES,否则输出NO。

    样例输入

    3
    a1b2c3d4
    Linle@ACM
    ^~^@^@!%
    

    样例输出

    NO
    YES
    NO
    #include<iostream>
    #include<string>
    using namespace std;
    //大写字母65-90,小写字母97-122,数字48-57,特殊符号126,64,33,35,36,37,94
    void judge(string str)
    {
        int count = 0;
        int status[5] = { 0 };
        if (str.length() >= 8 && str.length() <= 16)
        {
            for (int i = 0; i <= str.length(); i++)
            {
                int k = str[i];
                if (status[1] == 0)
                {
                    if (k >= 65 && k <= 90)
                    {
                        count++;
                        status[1] = 1;
                    }
                }
                if (status[2] == 0)
                {
                    if (k >= 97 && k <= 122)
                    {
                        count++;
                        status[2] = 1;
                    }
                }
                if (status[3] == 0)
                {
                    if (k >= 48 && k <= 57)
                    {
                        count++;
                        status[3] = 1;
                    }
                }
                if (status[4] == 0)
                {
                    if (k == 126 || k == 64 || k == 33 || k == 35 || k == 36 || k == 37 || k == 94)
                    {
                        count++;
                        status[4] = 1;
                    }
                }
            }
        }
        if (count >= 3)
        {
            cout << "YES" << endl;
        }
        else
        {
            cout << "NO" << endl;
        }
    }
    int main()
    {
        int n;
        string keyword;
        cin >> n;
        for (int i = 0; i < n; i++)
        {
            cin >> keyword;
            judge(keyword);
        }
        return 0;
    }
  • 相关阅读:
    alpha版本冲刺总结
    近两天项目冲刺
    关于微软必应词典客户端 的案例分析
    第三次作业——结队编程
    hdu 1002 A + B Problem II(大数)
    ZOJ 3805 Machine(二叉树,递归)
    hdu 4704 sum(费马小定理+快速幂)
    欧拉图
    hdu 1116 Play on Words(欧拉通路)
    前50个斐波那契数
  • 原文地址:https://www.cnblogs.com/Lazy-Cat/p/9838486.html
Copyright © 2020-2023  润新知