zoukankan      html  css  js  c++  java
  • 设计密码

    网上流传一句话:“常在网上飘啊,哪能不挨刀啊”。其实要想能安安心心地上网其实也不难,学点安全知识就可以。 首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件: (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;
    }
  • 相关阅读:
    CodeVs 1295 N皇后问题
    POJ 3349 Snowflake Snow Snowflakes
    链表API
    Hash API
    CodeVS 1220 数字三角形
    CodeVS 1045 回文数
    CodeVS 1058 合唱队形(DP--最长子序列问题)
    CodeVS 1018 单词接龙(DFS)
    关于图覆盖问题习题BY石家名
    软件测试作业(二)
  • 原文地址:https://www.cnblogs.com/Lazy-Cat/p/9838486.html
Copyright © 2011-2022 走看看