题解 | #密码验证合格程序#

密码验证合格程序

https://www.nowcoder.com/practice/184edec193864f0985ad2684fbc86841

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

string IsRight(string s){
    //1.长度超过8位
    if (s.length() < 8) 
        return "NG";
    
    //2.包括大小写字母.数字.其它符号,以上四种至少三种
    string str = "abcdefghijklmnopqrstuvwxyz"
                  "ABCDEFGHIJKLMNOPQRSTUVWXYZ"
                  "0123456789"
                  "~`!@#$%^&*(){}[]|;:',./<>?-=——+";

    int f1 = 0, f2 = 0, f3 = 0,f4 = 0;
    for (int i = 0; i < s.length(); i++){
        if (f1+f2+f3+f4 >= 3) break;

        int pos = str.find(s[i]);
        if (pos >= 0 && pos <= 25){
            f1 = 1;
        }
        else if (pos > 25 && pos <= 51){
            f2 = 1;
        }
        else if (pos > 51 && pos <= 61){
            f3 = 1;
        }
        else if (pos > 61 && pos < str.length()){
            f4 = 1;
        }
    }
    if (f1+f2+f3+f4 < 3) 
        return "NG";

    // 3.不能有长度大于2的包含公共元素的子串重复
    int m = 0;
    bool flag = false;
    while (m < s.length()-3){
        string tmp1 = s.substr(m, 3);
        string tmp2 = s.substr(m+3, s.length()-m-2);
        int pos = tmp2.find(tmp1);
        if (pos >= 0){
            flag = true;
            break;
        }
        m += 1;
    }
    if (flag)
        return "NG";

    return "OK";
}
int main() 
{
    string s;
    while (cin >> s){
        cout << IsRight(s) << endl;
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

今天投了小鹏,收到了AI面,大概会问哪些啊?
期末一定及格:总共4个部分,心理测评、行测、然后就是问岗位、对岗位的理解、过往遇到了哪些难点怎么解决,很简单,没有什么特别专业的问题,都是一些综合素质相关的
小鹏汽车AI面6人在聊
点赞 评论 收藏
分享
05-25 10:45
门头沟学院 Java
Frank_zhan...:没实习一个项目肯定不够,可以再做一个轮子,技术栈再补一个mq,微服务,整体再换个简历模板,暑期尽量再找一个日常实习
无实习如何秋招上岸
点赞 评论 收藏
分享
asdasdasda...:19岁,不容易啊可能升个本会好点,现在学历歧视太严重了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务