[每日一题]59:密码强度等级

122 篇文章 36 订阅
51 篇文章 0 订阅

题目描述

密码按如下规则进行计分,并根据不同的得分为密码进行安全等级划分。
一、密码长度:
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
数字:-9
符号包含如下: (ASCII码表可以在UltraEdit的菜单view->ASCII Table查看)
!"#$%&’()*+,-./ (ASCII码:x21~0x2F)
:;<=>?@ (ASCII<=><=><=><=><=>码:x3A~0x40)
[]^_` (ASCII码:x5B~0x60)
{|}~ (ASCII码:x7B~0x7E)

输入描述:

输入一个string的密码

输出描述:

输出密码等级

示例1

输入
38$@NoNoNo

输出
VERY_SECURE

思路:

由于这里对于不同种类的字符得分不同,现对每一个维度进行单独判断,即对于长度,字母,数字,符号单独判断,最后把所有的单项值根据题目要求相加,输出对应的安全级别。

解答代码:

#include<iostream>
#include<string>
using namespace std;

int numChar(string str, int k)
{
    //根据ASCII码判断字母大小写 
    int small = 0;
    int big = 0;
        for (int i = 0; i < k; i++) {
            if (str[i] >= 65 && str[i] <= 90)   // 大写字符
                big++;
            else if (str[i] >= 97 && str[i] <= 122) // 小写字符
                small++;
    }

    if ((small + big) == 0)
        return 0;
    else if (small == k || big == k)
        return 10;
    else //if (small > 0 && big > 0)
        return 20;
    //return 0;
}

int numNumber(string str, int k)
{
    //根据ASCII码判断数字个数,减去字符‘0’之后在0~9之间的即为数字 
    int num = 0;
    for (int i = 0; i < k; i++)
    {
        if (str[i] - '0' >= 0 && str[i] - '0' <= 9)
            num++;
    }

    if (num == 0)
        return 0;
    else if (num == 1)
        return 10;
    else
        return 20;
}

int numSymbal(string str, int k)
{
    int num = 0;
    for (int i = 0; i < k; i++)
    {
        //除去字母,数字,其它都为符号
        if (!(str[i] >= 65 && str[i] <= 90)
            && !(str[i] >= 97 && str[i] <= 122)
            && !(str[i] - '0' >= 0 && str[i] - '0' <= 9))
            num++;
    }

    if (num == 0)
        return 0;
    else if (num == 1)
        return 10;
    else
        return 25;
}

int main() {
    string str;
    while (cin >> str) {
        int sum1 = 0, sum2 = 0, sum3 = 0, sum4 = 0, sum5 = 0;

        int k = str.size(); // 得到字符串的长度分数
        if (k <= 4)
            sum1 = 5;
        else if (k >= 8)
            sum1 = 25;
        else
            sum1 = 10;

        sum2 = numChar(str, k);     // 得到字母分数
        sum3 = numNumber(str, k);   // 得到数字分数
        sum4 = numSymbal(str, k);   // 得到符号分数

        // 奖励分
        if ((sum2 > 0) && (sum3 > 0) && (sum4 > 0))
        {
            if (sum2 == 10)
                sum5 = 3;
            else
                sum5 = 5;
        }
        else if (sum2 > 0 && sum3 > 0 && sum4 == 0)
            sum5 = 2;

        int sum = sum1 + sum2 + sum3 + sum4 + sum5; // 总得分
        if (sum >= 90)
            cout << "VERY_SECURE" << endl;
        else if (sum >= 80)
            cout << "SECURE" << endl;
        else if (sum >= 70)
            cout << "VERY_STRONG" << endl;
        else if (sum >= 60)
            cout << "STRONG" << endl;
        else if (sum >= 50)
            cout << "AVERAGE" << endl;
        else if (sum >= 25)
            cout << "WEAK" << endl;
        else
            cout << "VERY_WEAK" << endl;
    }
    return 0;
}

代码生成图:
在这里插入图片描述


如有不同见解,欢迎留言讨论~~

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值