设计密码

设计密码网上流传一句话:“常在网上飘啊,哪能不挨刀啊”。其实要想能安安心心地上网其实也不难,学点安全知识就可以。首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件:(1)密码长度大于等于8,且不要超过16。(2)密码中的字符应该来自下面“字

大家好,欢迎来到IT知识分享网。设计密码"

网上流传一句话:“常在网上飘啊,哪能不挨刀啊”。其实要想能安安心心地上网其实也不难,学点安全知识就可以。 首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件: (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;
}

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/34135.html

(0)

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信