一个判断密码强度问题:
假设允许采用以下四类字符作为密码:
(1)大写英文字母,(2)小写英文字母,(3)数字0-9,(4)特殊符号 @ - _ # ~
对密码强度做以下规定:
Best: 长度>=16,且包含以上四类字符,且每类至少有两个不同的字符
Strong: 不符合Best规定,但长度>=10,且包含以上四类字符
Medium: 不符合Best、Strong规定,但长度>=8,且包含以上至少三类字符
Weak:不符合Best、Strong、Medium规定。
现给你一个密码组合,请判断密码强度。
输入格式:一行字符串(长度<100,以换行结束),且保证都是以上四类字符。
输出格式:一行信息,先输出密码长度,然后是强度等级,中间空一格。
输入样例1:[email protected]_-#
输出样例1:16 Best
输入样例2:12345678abcdefghXYZ
输出样例2:19 Medium
输入样例3:[email protected]
输出样例3:4 Weak
题目关键在于Best里面的每类至少有两个不同的字符,若想实现此功能可以定义多个数组。
c源代码:
#include"stdio.h"
int main()
{
char a[100],sz[100],ZM[100],zm[100],fh[100];
int i,j,k,l,m,n,sum,zm0,ZM0,sz0,fh0;
i=0;
k=l=m=n=0;
zm0=0;
ZM0=0;
sz0=0;
fh0=0;
sum=0;
while((a[i]=getchar())!=‘\n‘)
{
i++;
}
for(j=0;j<i;j++)
{
if(a[j]>=‘A‘&&a[j]<=‘Z‘)
{
ZM[k]=a[j];
k++;
}
else if(a[j]>=‘a‘&&a[j]<=‘z‘)
{
zm[l]=a[j];
l++;
}
else if(a[j]>=‘0‘&&a[j]<=‘9‘)
{
sz[m]=a[j];
m++;
}
else
{
fh[n]=a[j];
n++;
}
}
sum=k+l+m+n;
while(k--)
{
ZM0++;
if(ZM[k]==ZM[k-1])
ZM0--;
}
while(l--)
{
zm0++;
if(zm[l]==zm[l-1])
zm0--;
}
while(m--)
{
sz0++;
if(sz[m]==sz[m-1])
sz0--;
}
while(n--)
{
fh0++;
if(fh[n]==fh[n-1])
fh0--;
}
if(sum>=16&&ZM0>=2&&zm0>=2&&sz0>=2&&fh0>=2)
printf("%d Best\n",sum);
else if(sum>=10&&ZM0>=1&&zm0>=1&&sz0>=1&&fh0>=1)
printf("%d Strong\n",sum);
else if(sum>=8&&((ZM0>=1&&zm0>=1&&sz0>=1)||(zm0>=1&&ZM0>=1&&fh0>=1)||(zm0>=1&&sz0>=1&&fh0>=1)))
printf("%d Medium\n",sum);
else
printf("%d Weak\n",sum);
return 0;
}