zoukankan      html  css  js  c++  java
  • 算法 密码验证合格程序

    题目描述

    密码要求:

    1.长度超过8位

    2.包括大小写字母.数字.其它符号,以上四种至少三种

    3.不能有相同长度超2的子串重复

    说明:长度超过2的子串

    输入描述:

    一组或多组长度超过2的子符串。每组占一行

    输出描述:

    如果符合要求输出:OK,否则输出NG

    示例1

    输入

    复制
    021Abc9000
    021Abc9Abc1
    021ABC9000
    021$bc9000
    

    输出

    复制
    OK
    NG
    NG
    OK

    思路:
       重复字串不能大于2【从子串长度3开始到最后遍历DesStr,若有找到则不满足】
       字符串种类大于3【a-z】【A-Z】【0-9】【other】

    参考讨论:  

    #include <iostream>
    #include <string>
    using namespace std;
    int main(){
      string str;
      while(cin >> str){
        int flag[4] = {0};
        if(str.size() <= 8) goto NG;
          for(int i = 0; i < str.size(); ++i)
            if(str[i] >= 'a' && str[i] <= 'z') flag[0] = 1;
            else if(str[i] >= 'A' && str[i] <= 'Z') flag[1] = 1;
            else if(str[i] >= '0' && str[i] <= '9') flag[2] = 1;
            else flag[3] = 1;
            if(flag[0] + flag[1] + flag[2] + flag[3] < 3) goto NG;
              for(int i = 0; i <= str.size()-6; i++)
              for(int j = i+3;j < str.size();j++)
                if(str[i] == str[j] && str[i+1] == str[j+1] &&str[i+2] == str[j+2]) goto NG;
          OK:
            cout << "OK" << endl;continue;
          NG:
            cout << "NG" << endl;
    }
      return 0;
    }

    有点暴力。

  • 相关阅读:
    中英切换
    vue-cli3 关闭一直运行的 /sockjs-node/info?t= ...
    vue 深拷贝
    C++ 中 typename
    将博客搬至CSDN
    死锁及处理
    C 运算符优先级
    阻塞与非阻塞,同步与异步
    同步函数与异步函数
    C 结构体位域
  • 原文地址:https://www.cnblogs.com/liuruoqian/p/11654608.html
Copyright © 2011-2022 走看看