HJ20 密码验证合格程序

题目:

HJ20 密码验证合格程序

题解:

3.不能有长度大于2的包含公共元素的子串重复

采用长度为三的滑动窗口,截取子串,判断子串是否在密码中重复出现。


    public boolean validPassword(String password) {
        if (password.length() <= 8) {
            return false;
        }

        char[] chars = password.toCharArray();
        int exitUppercase = 0;
        int exitLowercase = 0;
        int exitNumber = 0;
        int exitOther = 0;
        boolean success = false;

        for (char aChar : chars) {
            if (isUppercase(aChar)) {
                exitUppercase = 1;
            }
            if (isLowercase(aChar)) {
                exitLowercase = 1;
            }
            if (isNumber(aChar)) {
                exitNumber = 1;
            }
            if (isOther(aChar)) {
                exitOther = 1;
            }

            if (exitUppercase + exitLowercase + exitNumber + exitOther >= 3) {
                success = true;
            }
        }

        if (!success) {
            return false;
        }


        for (int i = 0; i < chars.length-3; i++) {
            int j = i+3;
            String subString = password.substring(i, j);
            if (password.indexOf(subString) != password.lastIndexOf(subString)) {
                return false;
            }
        }

        return true;
    }

    public boolean isUppercase(char ch) {
        return ch >= 'A' && ch <= 'Z';
    }

    public boolean isLowercase(char ch) {
        return ch >= 'a' && ch <= 'z';
    }

    public boolean isNumber(char ch) {
        return ch >= '0' && ch <= '9';
    }

    public boolean isOther(char ch) {
        return !isUppercase(ch) && !isLowercase(ch) && !isNumber(ch) && ch != ' ' && ch !='\n';
    }

时间复杂度:O(n)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值