题目描述:

如果一个密码满足以下所有条件,我们称它是一个 强 密码:

    它有至少 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; } }

技术
下载桌面版
GitHub
百度网盘(提取码:draw)
Gitee
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:766591547
关注微信