密码合规

题目描述

网站注册需要有用户名和密码,编写程序以检查用户输入密码的有效性。合规的密码应满足以下要求 :。

  1. 只能由a∼z 之间 26 个小写字母,A∼Z 之间 26 个大写字母,0∼9 之间 10 个数字以及 !@#$ 四个特殊字符构成。

  2. 密码最短长度 :6 个字符,密码最大长度 :12 个字符。

  3. 大写字母,小写字母和数字必须至少有其中两种,以及至少有四个特殊字符中的一个。

输入格式

输入一行不含空格的字符串。约定长度不超过 100。该字符串被英文逗号分隔为多段,作为多组被检测密码。

输出格式

输出若干行,每行输出一组合规的密码。输出顺序以输入先后为序,即先输入则先输出。

输入输出样例

输入 #1复制

seHJ12!@,sjdkffH$123,sdf!@&12HDHa!,123&^YUhg@!

输出 #1复制

seHJ12!@
sjdkffH$123

说明/提示

【样例 1 解释】

输入被英文逗号分为了四组被检测密码:seHJ12!@sjdkffH$123sdf!@&12HDHa!123&^YUhg@!。其中 sdf!@&12HDHa! 长度超过 12 个字符,不合规;123&^YUhg@! 包含四个特殊字符之外的字符不合规。

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

bool isValidPassword(const string& password)
{
    if (password.length() < 6 || password.length() > 12) {
        return false;  // 长度不在要求范围内
    }

    bool hasLower = false;
    bool hasUpper = false;
    bool hasDigit = false;
    int specialCount = 0;

    for (char ch : password) {
        if (islower(ch)) {
            hasLower = true;
        } else if (isupper(ch)) {
            hasUpper = true;
        } else if (isdigit(ch)) {
            hasDigit = true;
        } else if (ch == '!' || ch == '@' || ch == '#' || ch == '$') {
            specialCount++;
        } else {
            return false;  // 包含非法字符
        }
    }

    if (specialCount < 1 || (hasLower + hasUpper + hasDigit) < 2) {
        return false;  // 不满足字符种类和特殊字符个数的要求
    }

    return true;
}

int main() {
    string input;
    getline(cin, input);

    // 使用逗号分割输入的字符串
    vector<string> passwords;
    string temp = "";
    for (char ch : input) {
        if (ch == ',') {
            passwords.push_back(temp);
            temp = "";
        } else {
            temp += ch;
        }
    }
    passwords.push_back(temp);  // 加入最后一个密码

    // 检查密码并输出合规密码
    for (const string& pw : passwords) {
        if (isValidPassword(pw)) {
            cout << pw << endl;  // 输出合规的密码
        }
    }

    return 0;
}

<< 洛谷 B3843 密码合规是一道涉及字符串处理、条件判断以及规则匹配的问题。题目要求我们根据特定的密码策略检查给定的一组密码是否符合规定。 以下是对该题目的解答思路与完整代码: --- ### 解决方案 **题目分析:** 我们需要验证每个密码是否满足以下几个条件(假设这些是常见的密码复杂度需求): 1. 长度至少为 6 个字符。 2. 包含字母数字,且必须同时包含大小写字母。 3. 不包含空格或其他特殊字符。 4. 可能还有其他额外规则(具体依赖于实际题意说明)。 我们可以逐条编写逻辑来检测上述条件,并输出结果。 ```cpp #include <iostream> #include <string> using namespace std; bool isPasswordCompliant(const string& password) { if (password.length() < 6) return false; // 检查长度是否大于等于6 bool hasLower = false, hasUpper = false, hasDigit = false; for(char c : password){ if(islower(c)) hasLower = true; // 是否有小写字母 else if(isupper(c)) hasUpper = true; // 是否有大写字母 else if(isdigit(c)) hasDigit = true; // 是否有数字 if (!isalnum(c)) return false; // 如果出现非字母或数字直接返回false } return hasLower && hasUpper && hasDigit; // 必须同时包含小写、大写及数字 } int main(){ int n; cin >> n; while(n--){ string pwd; cin >> pwd; if(isPasswordCompliant(pwd)){ cout << "YES" << endl; }else{ cout << "NO" << endl; } } return 0; } ``` #### **解释** 1. `isPasswordCompliant` 函数用于判断一个密码是否合法。这个函数首先检查了密码长度是否小于6;接着初始化三个布尔值分别用来记录是否存在小写字母 (`hasLower`)、大写字母(`hasUpper`) 数字(`hasDigit`)。 2. 在遍历每一个字符时,使用 C++ 标准库中的 `islower`, `isupper`, `isdigit` 来分类标记相的特征。如果发现任何非法字符(即不是字母也不是数字),立即返回 `false` 表示不合规。 3. 最后,在所有循环完成后,只有当这三种必需元素都存在的情况下才会返回真,否则判定此串不符合密码设定规范。 4. 主程序部分读取输入次数并逐一调用合法性校验器打印对的结果“YES” 或者 “NO”。 --- ### 注意事项 - 输入可能含有空白行或者其他意外符号情况需特别注意过滤掉无效数据避免干扰最终判断依据。 - 对某些特殊情况如极端短密码等要确保算法健壮性能够正确对边界测试样例。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值