zoukankan      html  css  js  c++  java
  • 密码 hdu

    Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other)

    Total Submission(s) : 14   Accepted Submission(s) : 4

    Font: Times New Roman | Verdana | Georgia

    Font Size:  

    Problem Description


    网上流传一句话:"常在网上飘啊,哪能不挨刀啊~"。其实要想能安安心心地上网其实也不难,学点安全知识就可以。

    首先,我们就要设置一个安全的密码。那什么样的密码才叫安全的呢?一般来说一个比较安全的密码至少应该满足下面两个条件:

    (1).密码长度大于等于8,且不要超过16。
    (2).密码中的字符应该来自下面“字符类别”中四组中的至少三组。

    这四个字符类别分别为:
    1.大写字母:A,B,C...Z;
    2.小写字母:a,b,c...z;
    3.数字:0,1,2...9;
    4.特殊符号:~,!,@,#,$,%,^;

    给你一个密码,你的任务就是判断它是不是一个安全的密码。

    Input

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

    Output

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

    Sample Input

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

    Sample Output

    NO
    YES
    NO
    #include<Iostream>
    using namespace std;
    int main()
    {
        char a[32];
        int n,i,len,k1,k2,k3,k4;
        cin>>n;
        while(n--)
        {k1=k2=k3=k4=0;
            cin>>a;
            len=strlen(a);
            if(len<8||len>16)
                cout<<"NO"<<endl;
            else
            {
                for(i=0;i<len;i++)
        {
         if(a[i]>='0'&&a[i]<='9')
         k1=1;
        
         if(a[i]>='a'&&a[i]<='z')
         k2=1;
        
         if(a[i]>='A'&&a[i]<='Z')
         k3=1;
         if(a[i]=='~' || a[i]=='!' ||a[i]=='@' || a[i]=='#' ||a[i]=='$' || a[i]=='%' ||a[i]=='^')
         k4=1;
        }
                 if((k1+k2+k3+k4)>=3)
                     cout<<"YES"<<endl;
                 else
                     cout<<"NO"<<endl;
    
                
            
            }
    
            
        
        }
    
    return 0;
    }


  • 相关阅读:
    [NOIp2017] 列队
    [CQOI2009] 中位数
    [洛谷P1419] 寻找段落
    [HNOI2001] 产品加工
    [洛谷P1842] 奶牛玩杂技
    [SCOI2006] 数字立方体
    [LOJ10121] 与众不同
    [USACO10MAR] 伟大的奶牛聚集
    [HAOI2010] 软件安装
    [洛谷P1357] 花园
  • 原文地址:https://www.cnblogs.com/oversea201405/p/3766955.html
Copyright © 2011-2022 走看看