记录每日LeetCode 2299.强密码校验器II Java实现
阿里云国内75折 回扣 微信号:monov8 |
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6 |
题目描述
如果一个密码满足以下所有条件我们称它是一个 强 密码
它有至少 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;
}
}