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

密码验证合格程序

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

import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        String str;
        while (in.hasNext()) {
            str = in.next();
            //重点,该输出NG的情况要包含完,各种情况符合都为NG,走遍了之后没有输出ng,最后就是OK

            // 检查长度是否超过8位
            if (str.length() <= 8) {
                System.out.println("NG");
                continue;
            }

            // 检查是否包括大小写字母、数字、其它符号中的至少三种
            int countTypes = 0;
            if (str.matches(".*[0-9].*")) countTypes++;
            if (str.matches(".*[a-z].*")) countTypes++;
            if (str.matches(".*[A-Z].*")) countTypes++;
            if (str.matches(".*[^a-zA-Z0-9 ].*")) countTypes++; // 包括其他符号
            if (countTypes < 3) {
                System.out.println("NG");
                continue;
            }

            // 检查是否有长度大于2的公共子串重复
            boolean hasRepeatingSubstring = hasRepeatingSubstring(str, 3);
            if (hasRepeatingSubstring) {
                System.out.println("NG");
                continue;
            }

            // 如果所有检查都通过,则输出"OK"
            System.out.println("OK");
        }
        in.close();
    }

    // 辅助方法,检查字符串是否有长度大于等于指定长度的重复子串
   private static boolean hasRepeatingSubstring(String str, int minLength) {
    int len = str.length();
    //012012012
    for (int i = 0; i < len - minLength; i++) {//0-2
        for (int j = i + minLength; j <= len-minLength; j++) {//0-2
		  //这两种if判断都通过了,不过底下的可以少判断几次【substring(1,4)即取得1,2,3】
            // if (str.substring(i, i + minLength).equals(str.substring(j - minLength+1, j+1 ))) {
                if (str.substring(i, i + minLength).equals(str.substring(j , j+minLength ))) {
                //0,2   ---1,0【】j+minlength
                return true;
            }
        }
    }
    return false;
}
}

全部评论

相关推荐

手撕没做出来是不是一定挂
Chrispp3:不会,写出来也不一定过
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务