记录每日LeetCode 2299.强密码校验器II Java实现
题目描述:
如果一个密码满足以下所有条件,我们称它是一个 强 密码:
它有至少 8 个字符。 至少包含 一个小写英文 字母。 至少包含 一个大写英文 字母。 至少包含 一个数字 。 至少包含 一个特殊字符 。特殊字符为:"!@#$%^&*()-+" 中的一个。 它 不 包含 2 个连续相同的字符(比方说 "aab" 不符合该条件,但是 "aba" 符合该条件)。
给你一个字符串 password ,如果它是一个 强 密码,返回 true,否则返回 false 。
初始代码:
class Solution { public boolean strongPasswordCheckerII(String password) { } }
示例1:
输入:password = "IloveLe3tcode!" 输出:true 解释:密码满足所有的要求,所以我们返回 true 。
示例2:
输入:password = "Me+You--IsMyDream" 输出:false 解释:密码不包含数字,且包含 2 个连续相同的字符。所以我们返回 false 。
示例3:
输入:password = "1aB!" 输出:false 解释:密码不符合长度要求。所以我们返回 false 。
参考答案:
//这道题主要需要掌握的是Java的Api中的Character //Character.isLowerCase();Character.isUpperCase();Character.isDigit() class Solution { public boolean strongPasswordCheckerII(String password) { if(password.length() < 8) return false; //用于存放特殊字符的集合 List<Character> list = new ArrayList<>(); list.add(!); list.add(@); list.add(#); list.add($); list.add(%); list.add(^); list.add(&); list.add(*); list.add((); list.add()); list.add(-); list.add(+); //通过校验的标识 boolean isLowerCase = false,isUpperCase = false,isDigit = false,isSpecialChar = false; for(int i = 0;i < password.length();++i){ char pwd = password.charAt(i); //需要判断连续两个字符是否相等并且保证数组下标不越界 if(i > 0 && password.charAt(i - 1) == pwd) return false; if (Character.isLowerCase(pwd)) { isLowerCase = true;//表明至少包含了1个小写英文字母 } else if (Character.isUpperCase(pwd)) { isUpperCase = true;//表明至少包含了1个大写英文字母 } else if (Character.isDigit(pwd)) { isDigit = true;//表明至少包含了1个数字 } else if(list.contains(pwd)){ isSpecialChar = true;//表明集合内确实存在至少1个特殊字符 } } //当四个条件皆成立即返回true return isLowerCase && isUpperCase && isDigit && isSpecialChar; } }
下一篇:
深入理解虚拟机原理与实现