Time Limit: 2000/1000 MS (java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 52915 Accepted Submission(s): 21376
網(wǎng)上流傳一句話:”常在網(wǎng)上飄啊,哪能不挨刀啊~”。其實(shí)要想能安安心心地上網(wǎng)其實(shí)也不難,學(xué)點(diǎn)安全知識(shí)就可以。
首先,我們就要設(shè)置一個(gè)安全的密碼。那什么樣的密碼才叫安全的呢?一般來(lái)說一個(gè)比較安全的密碼至少應(yīng)該滿足下面兩個(gè)條件:
(1).密碼長(zhǎng)度大于等于8,且不要超過16。 (2).密碼中的字符應(yīng)該來(lái)自下面“字符類別”中四組中的至少三組。
這四個(gè)字符類別分別為: 1.大寫字母:A,B,C…Z; 2.小寫字母:a,b,c…z; 3.數(shù)字:0,1,2…9; 4.特殊符號(hào):~,!,@,#,$,%,^;
給你一個(gè)密碼,你的任務(wù)就是判斷它是不是一個(gè)安全的密碼。
Input
輸入數(shù)據(jù)第一行包含一個(gè)數(shù)M,接下有M行,每行一個(gè)密碼(長(zhǎng)度最大可能為50),密碼僅包括上面的四類字符。
Output
對(duì)于每個(gè)測(cè)試實(shí)例,判斷這個(gè)密碼是不是一個(gè)安全的密碼,是的話輸出YES,否則輸出NO。
Sample Input
3 a1b2c3d4 Linle@ACM ^~^@^@!%
Sample Output
NO YES NO
日常水題,只要判斷字符串中有幾種類型就OK。
#include<stdio.h>#include<stdlib.h>#include<string.h>int main(){ int len,i,n; char ch[55],a[4]; scanf("%d",&n); while(n--){ scanf("%s",ch); len=strlen(ch); if(len<8||len>16){ printf("NO/n"); continue; } else{ for(i=0;i<4;i++) a[i]=0; for(i=0;i<len;i++){ if(ch[i]>='A'&&ch[i]<='Z'){ a[0]=1; } else if(ch[i]>='a'&&ch[i]<='z'){ a[1]=1; } else if(ch[i]>='0'&&ch[i]<='9'){ a[2]=1; } else if(!a[3]){ a[3]=1; } } if(a[0]+a[1]+a[2]+a[3]>=3) printf("YES/n"); else printf("NO/n"); } } return 0;}
|
新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注