![]()
![]()
为了判断满足的条件数可以立个flag(∩( ・ω・)∩萌萌哒) 满足该条件就是flag = 1 , 不满足 flag 就是0 , 然后把众 flag 相加 >=3 就是满足三个及其以上条件((*´艸`) 吼吼吼)
剩下要做的就是遍历输入字符串看看该密码是不是满足要求
#include<stdio.h>
#include<string.h>
#define N 51
int main()
{
int n;
int flag1 = 0 , flag2 = 0 , flag3 = 0 , flag4 = 0;
char pasw[N];
scanf("%d" , &n);
getchar();
for(int i=0; i<n; i++)
{
gets(pasw);
if(strlen(pasw) < 8 || strlen(pasw) > 16)
{
printf("NO\n");
continue;
}
for(int p=0; p<strlen(pasw); p++)
{
if(pasw[p] >= 'A' && pasw[p] <= 'Z')
flag1 = 1;
else if(pasw[p] >='a' && pasw[p] <= 'z')
flag2 = 1;
else if(pasw[p] >= '0' && pasw[p] <= '9')
flag3 = 1;
else if(pasw[p] == '~' || pasw[p] == '!' || pasw[p] == '@' ||
pasw[p] == '#' || pasw[p] == '$' || pasw[p] == '%' || pasw[p] == '^')
flag4 = 1;
}
if((flag1 + flag2 + flag3 + flag4) > 2)
printf("YES\n");
else printf("NO\n");
flag1 = 0 , flag2 = 0 , flag3 = 0 , flag4 = 0;
}
return 0;
}