poj2043 密码

Posted auroras

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了poj2043 密码相关的知识,希望对你有一定的参考价值。



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 [email protected] ^~^@^@!%
 

 

Sample Output
NO YES NO
 
   一道水题,一开始嫌麻烦没做,后来想到一个比较好的处理方法。还有注的是密码的长度8~16.
AC Code:
技术图片
 1 #include<iostream>
 2 #include<iomanip>
 3 #include<cstdio>
 4 #include<cstdlib>
 5 #include<cstring>
 6 #include<cmath>
 7 #include<string>
 8 #include<algorithm>
 9 #include<vector>
10 #include<map>
11 #include<stack>
12 #include<queue>
13 #include<deque>
14 #include<set>
15 #include<cctype>
16 #define maxn (int)1e5
17 #define INF 0x3f3f3f3f
18 using namespace std;
19 int main()
20 
21     ios::sync_with_stdio(false);
22     cin.tie(0);
23     cout.tie(0);
24     #ifndef ONLINE_JUDGE
25     freopen("input.txt","r",stdin);
26     #endif
27    int T;
28    set<char> st;
29    st.insert(~),st.insert(!),st.insert(@),st.insert(#),st.insert($),st.insert(%),st.insert(^);
30    string s;
31    cin>>T;
32    while(T--)
33    
34        cin>>s;
35        int l=s.size();
36        if(l<8||l>16) 
37         cout<<"NO"<<endl;
38         continue;
39        
40        int num1=0,num2=0,num3=0,num4=0;
41        for(int i=0;i<l;++i)
42        
43            if(isdigit(s[i])) num1=1;
44            if(isupper(s[i])) num2=1;
45            if(isalpha(s[i])) 
46             if(!isupper(s[i])) num3=1;
47            
48            if(st.count(s[i])) num4=1;
49 
50        
51        if(num1+num2+num3+num4>=3) cout<<"YES"<<endl;
52        else cout<<"NO"<<endl;
53    
54 
55 
View Code

 

以上是关于poj2043 密码的主要内容,如果未能解决你的问题,请参考以下文章

杭电oj2043密码

HDU - 2043密码 水题

HDU_oj_2043 密码

POJ2043 Area of Polygons

POJ2043.Area of Polygons

POJ3749 破译密码