HJ87 密码强度等级(一把过)

描述
密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分。

一、密码长度:

5 分: 小于等于4 个字符

10 分: 5 到7 字符

25 分: 大于等于8 个字符

二、字母:

0 分: 没有字母

10 分: 全都是小(大)写字母

20 分: 大小写混合字母

三、数字:

0 分: 没有数字

10 分: 1 个数字

20 分: 大于1 个数字

四、符号:

0 分: 没有符号

10 分: 1 个符号

25 分: 大于1 个符号

五、奖励:

2 分: 字母和数字

3 分: 字母、数字和符号

5 分: 大小写字母、数字和符号

最后的评分标准:

>= 90: 非常安全

>= 80: 安全(Secure)

>= 70: 非常强

>= 60: 强(Strong)

>= 50: 一般(Average)

>= 25: 弱(Weak)

>= 0:  非常弱


对应输出为:

VERY_SECURE

SECURE

VERY_STRONG

STRONG

AVERAGE

WEAK

VERY_WEAK


请根据输入的密码字符串,进行安全评定。

注:

字母:a-z, A-Z

数字:0-9

符号包含如下: (ASCII码表可以在UltraEdit的菜单view->ASCII Table查看)

!"#$%&'()*+,-./     (ASCII码:0x21~0x2F)

:;<=>?@             (ASCII码:0x3A~0x40)

[\]^_`              (ASCII码:0x5B~0x60)

{|}~                (ASCII码:0x7B~0x7E)



提示:
1 <= 字符串的长度<= 300
输入描述:
本题含有多组输入样例。
每组样例输入一个string的密码

输出描述:
每组样例输出密码等级

示例1
输入:
38$@NoNoNo
123
复制
输出:
VERY_SECURE
WEAK
复制
说明:
第一组样例密码强度为95分。
第二组样例密码强度为25分。    
示例2
输入:
Jl)M:+
复制
输出:
AVERAGE
复制
说明:
#include <stdio.h>
#include <string.h>

#if 0
#define dbg printf
#else
#define dbg
#endif

void print(int index)
{
    if(index >= 90)
    {
        printf("VERY_SECURE\n");
    }
    else if(index >= 80)
    {
        printf("SECURE\n");
    }
    else if(index >= 70)
    {
        printf("VERY_STRONG\n");
    }
    else if(index >= 60)
    {
        printf("STRONG\n");
    }
    else if(index >= 50)
    {
        printf("AVERAGE\n");
    }
    else if(index >= 25)
    {
        printf("WEAK\n");
    }
    else if(index >= 0)
    {
        printf("VERY_WEAK\n");
    }
}

int main(void)
{
    char a[301] = {0};
    int b[4] = {0};
    int out[32] = {0};
    int i, j;
    int len;
    
    j = 0;
    while(scanf("%s", a) != EOF)
    {
        dbg("(%d):a=%s\n", __LINE__, a);
        //1
        len = strlen(a);
        if(len <= 4)
        {
            dbg("(%d):\n", __LINE__);
            out[j] += 5;
        }
        else if(len <= 7)
        {
            dbg("(%d):\n", __LINE__);
            out[j] += 10;
        }
        else
        {
            dbg("(%d):\n", __LINE__);
            out[j] += 25;
        }

        memset(b, 0, sizeof(b));
        for(i=0; i<len; i++)
        {
            if(a[i]>='A' && a[i]<='Z')
            {
                b[0] = 1;
            }
            else if(a[i]>='a' && a[i]<='z')
            {
                b[1] = 1;
            }
            else if(a[i]>='0' && a[i]<='9')
            {
                b[2]++;
            }
            else
            {
                b[3]++;
            }
        }
        dbg("(%d):out[%d]=%d\n", __LINE__, j, out[j]);
        //2
        if((b[0]==1&&b[1]==0) || (b[1]==1&&b[0]==0))
        {
            out[j] += 10;
        }
        else if(b[0]==1 && b[1]==1)
        {
            out[j] += 20;
        }
        dbg("(%d):out[%d]=%d\n", __LINE__, j, out[j]);
        //3
        if(b[2] == 1)
        {
            out[j] += 10;
        }
        else if(b[2] > 1)
        {
            out[j] += 20;
        }
        dbg("(%d):out[%d]=%d\n", __LINE__, j, out[j]);
        //4
        if(b[3] == 1)
        {
            out[j] += 10;
        }
        else if(b[3] >= 2)
        {
            out[j] += 25;
        }
        dbg("(%d):out[%d]=%d\n", __LINE__, j, out[j]);
        //5
        if(b[0]==1 && b[1]==1 && b[2]>0 && b[3]>0)
        {
            out[j] += 5;
        }
        else if((b[0]==1||b[2]==1) && b[2]>0 && b[3]>0)
        {
            out[j] += 3;
        }
        else if((b[0]==1||b[2]==1) && b[2]>0 && b[3]==0)
        {
            out[j] += 2;
        }
        dbg("(%d):out[%d]=%d\n", __LINE__, j, out[j]);
        memset(a, 0, sizeof(a));
        j++;
    }

    for(i=0; i<j; i++)
    {
        print(out[i]);
    }
    
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值