美文网首页
JAVA 题目2_3级-密码强度等级-求最大连续bit数

JAVA 题目2_3级-密码强度等级-求最大连续bit数

作者: 华容三少 | 来源:发表于2020-06-19 22:58 被阅读0次

    201301 JAVA 题目2-3级

    题目描述

    请编写一个函数(允许增加子函数),计算n x m的棋盘格子(n为横向的格子数,m为竖向的格子数)沿着各自边缘线从左上角走到右下角,总共有多少种走法,要求不能走回头路,即:只能往右和往下走,不能往左和往上走。

    输入描述:

    输入两个正整数

    输出描述:

    返回结果
    示例
    输入:2 2
    输出:6

    #include<iostream>
    using namespace std;
    int func(int n, int m)
    {
        if (m == 0 || n == 0)
            return 1;
        return func(n - 1, m) + func(n, m - 1);
    }
    int main()
    {
        int m, n;
        while (cin >> n >> m)
            cout << func(n, m) << endl;
        return 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,
    请根据输入的密码字符串,进行安全评定。

    输入描述:

    输入一个string的密码

    输出描述:

    输出密码等级

    示例

    输入:38$@NoNoNo
    输出:VERY_SECURE

    #include<iostream>
    #include<string>
    using namespace std;
    int main()
    {
        string str;
        while (cin >> str){
            int c = 0, C = 0, n = 0, f = 0, ret = 0;
            int len = str.size();
            for (int i = 0; i < len; i++)
            {
                if (str[i] >= 'a'&&str[i] <= 'z')
                    c++;
                else if (str[i] >= 'A'&&str[i] <= 'Z')
                    C++;
                else if (str[i] >= '0'&&str[i] <= '9')
                    n++;
                else
                    f++;
            }
            //1.长度
            if (len <= 4)
                ret += 5;
            else if (len >= 5 && len <= 7)
                ret += 10;
            else
                ret += 25;
            //2.字母
            if ((c + C) == 1)
                ret += 10;
            else if ((c + C) > 1)
                ret += 20;
            //3.数字
            if (n == 1)
                ret += 10;
            else if (n > 1)
                ret += 20;
            //4.符号
            if (f == 1)
                ret += 10;
            else if (f > 1)
                ret += 25;
            //5.奖励
            if ((c + C) > 0 && n > 0)
            {
                ret += 2;
                if (f > 0)
                {
                    ret += 1;
                    if (c > 0 && C > 0)
                        ret += 2;
                }
            }
            if (ret >= 90)
                cout << "VERYSECURE" << endl;
            else if (ret >= 80)
                cout << "SECURE" << endl;
            else if (ret >= 70)
                cout << "VERY_STRONG" << endl;
            else if (ret >= 60)
                cout << "STRONG" << endl;
            else if (ret >= 50)
                cout << "AVERAGE" << endl;
            else if (ret >= 25)
                cout << "WEAK" << endl;
            else
                cout << "VERY_WAEK" << endl;
        }
        return 0;
    

    求最大连续bit数

    题目描述

    功能: 求一个byte数字对应的二进制数字中1的最大连续数,例如3的二进制为00000011,最大连续2个1
    输入: 一个byte型的数字
    输出: 无
    返回: 对应的二进制数字中1的最大连续数

    输入描述:

    输入一个byte数字

    输出描述:

    输出转成二进制之后连续1的个数
    示例1
    输入:3
    输出:2

    #include<iostream>
    using namespace std;
    int main()
    {
        int n;
        while (cin >> n){
            int ret = 0, cur = 0;
            while (n)
            {
                if ((n & 1) == 1)
                {
                    cur++;
                    if (cur>ret)
                        ret = cur;
                }
                else
                    cur = 0;
                n = n >> 1;
            }
            cout << ret << endl;
        }
        return 0;
    }
    

    相关文章

      网友评论

          本文标题:JAVA 题目2_3级-密码强度等级-求最大连续bit数

          本文链接:https://www.haomeiwen.com/subject/aucixktx.html