HDU-2043 密码

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)

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
 
  
3a1b2c3d4
Linle@ACM
^~^@^@!%  

Sample Output
 
  
NO
YES
NO

Author
linle


C++代码

#include<iostream>
using namespace std;
int main()
{
    char ch[60];
	int i,j,k;
	int n,s;
	cin>>n;
	while(n--)
    {
	int a[4]={0};
    	cin>>ch;
    	for(i=0;ch[i]!='\0';i++)
    	{
    		if(ch[i]>='A'&&ch[i]<='Z')
    		a[0]++;
    		else if(ch[i]>='a'&&ch[i]<='z')
    		a[1]++;
    		else if(ch[i]>='0'&&ch[i]<='9')
    		a[2]++;
    		else
    		a[3]++;
		}
		for(j=0,s=0;j<4;j++)
		{
			if(a[j]!=0)
			s++;
		}
		if(i>=8&&i<=16&&s>=3)
		cout<<"YES"<<endl;
		else
		cout<<"NO"<<endl;
	}
	return 0;
} 


当时错误的原因是数组a在每次循环的时候没有重置为0,导致从第二次数据流进来的时候,数组a还保留第一次数据流的信息,输出结果肯定有误。循环重置在循环结构中十分重要,也很容易被忽略,特此写此博客提醒自己和诸位。


猜你喜欢

转载自blog.csdn.net/hpu_ly/article/details/79626558