安全密码
CSU - 1262
时限: 1000MS | 内存: 131072KB | 64位IO格式: %lld & %llu |
已开启划词翻译
问题描述点击打开链接
网络上各类交易活动越来越普及,为了能够安安心心地上网,经常需要设置一个安全的密码。一般来说一个比较安全的密码至少应该满足下面两个条件:
(1)密码长度大于等于8。
(2)密码中的字符应该来自下面“字符类别”中四组中的至少三组。
这四个字符类别分别为:
(1)大写字母:A,B,C...Z;
(2)小写字母:a,b,c...z;
(3)数字:0,1,2...9;
(4)特殊符号:~,!,@,#,$,%,^;
给你一个密码,你的任务就是判断它是不是一个安全的密码。
输入
输入数据有多组,每组占一行,每行一个密码(长度最大可能为50),密码仅包括上面的四类字符。
输出
对于每个测试实例,判断这个密码是不是一个安全的密码,是的话输出YES,否则输出NO。
样例输入
a1b2c3d4 Linle@ACM ^~^@^@!%
样例输出
NO YES NO
直接查找,有符合类型的标记一下就是.
本题和hdoj 2043 密码 点击打开链接一样
代码:
#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<algorithm>
using namespace std;
char s[55];
int main()
{
while(gets(s)!=NULL)
{
int len=strlen(s);
if(len<8)
{
printf("NO\n");
continue;
}
int flag1=0,flag2=0,flag3=0,flag4=0;
for(int i=0;i<len;i++)
{
if(s[i]>='A'&&s[i]<='Z')
flag1=1;
else if(s[i]>='a'&&s[i]<='z')
flag2=1;
else if(s[i]>='0'&&s[i]<='9')
flag3=1;
else
flag4=1;
}
if(flag1+flag2+flag3+flag4>=3)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}