杭电oj2043密码
生活随笔
收集整理的這篇文章主要介紹了
杭电oj2043密码
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
Problem Description
網上流傳一句話:"常在網上飄啊,哪能不挨刀啊~"。其實要想能安安心心地上網其實也不難,學點安全知識就可以。
首先,我們就要設置一個安全的密碼。那什么樣的密碼才叫安全的呢?一般來說一個比較安全的密碼至少應該滿足下面兩個條件:
(1).密碼長度大于等于8,且不要超過16。
(2).密碼中的字符應該來自下面“字符類別”中四組中的至少三組。
這四個字符類別分別為:
1.大寫字母:A,B,C...Z;
2.小寫字母:a,b,c...z;
3.數字:0,1,2...9;
4.特殊符號:~,!,@,#,$,%,^;
給你一個密碼,你的任務就是判斷它是不是一個安全的密碼。
網上流傳一句話:"常在網上飄啊,哪能不挨刀啊~"。其實要想能安安心心地上網其實也不難,學點安全知識就可以。
首先,我們就要設置一個安全的密碼。那什么樣的密碼才叫安全的呢?一般來說一個比較安全的密碼至少應該滿足下面兩個條件:
(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 這道題就是對字符串的字符統計處理,也發現沒有什么陷阱,但通過率卻不足50%。 1 #include<iostream> 2 #include<cstring> 3 using namespace std; 4 int main() 5 { 6 int n,len,count[5],c; 7 char s[50]; 8 while(cin>>n) 9 { 10 cin.get();//必須加,讀取回車,否則下面的cin.getline()將讀入空行被堵塞 11 while(n--) 12 { 13 c = 0;//初始化 14 memset(count, 0, sizeof(int)*5);//memset按字節數(第三個參數)初始化 15 memset(s, '\0', 50); 16 cin.getline(s, 50); 17 len = strlen(s); 18 if(len<8||len>16)//長度不符 19 { 20 cout<<"NO"<<endl; 21 continue; 22 } 23 for(int i=0;i<len;i++) 24 { 25 if(s[i]>='A'&&s[i]<='Z') count[0]++;//字符為A~Z計數 26 else if(s[i]>='a'&&s[i]<='z') count[1]++; 27 else if(s[i]>='0'&&s[i]<='9') count[2]++; 28 else if(s[i]=='~'||s[i]=='!'||s[i]=='@'||s[i]=='#'||s[i]=='$'||s[i]=='%'||s[i]=='^') count[3]++; 29 else count[4]++; //其它字符計數 30 } 31 if(count[4])//有其它字符不符合 32 { 33 cout<<"NO"<<endl; 34 } 35 else 36 { 37 for(int i=0;i<4;i++) 38 if(count[i]) c++; 39 if(c<3) cout<<"NO"<<endl; 40 else cout<<"YES"<<endl; 41 42 } 43 } 44 } 45 return 0; 46 }?
轉載于:https://www.cnblogs.com/EdwinC/p/8934227.html
總結
以上是生活随笔為你收集整理的杭电oj2043密码的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: leetCode题解之Jewels an
- 下一篇: bzoj 1699: [Usaco200