如果一个密码满足以下所有条件,我们称它是一个 强 密码:
- 它有至少
8
个字符。 - 至少包含 一个小写英文 字母。
- 至少包含 一个大写英文 字母。
- 至少包含 一个数字 。
- 至少包含 一个特殊字符 。特殊字符为:
"!@#$%^&*()-+"
中的一个。 - 它 不 包含
2
个连续相同的字符(比方说"aab"
不符合该条件,但是"aba"
符合该条件)。
给你一个字符串 password
,如果它是一个 强 密码,返回 true
,否则返回 false
。
示例 1:
输入:password = "IloveLe3tcode!" 输出:true 解释:密码满足所有的要求,所以我们返回 true 。
示例 2:
输入:password = "Me+You--IsMyDream" 输出:false 解释:密码不包含数字,且包含 2 个连续相同的字符。所以我们返回 false 。
示例 3:
输入:password = "1aB!" 输出:false 解释:密码不符合长度要求。所以我们返回 false 。
提示:
1 <= password.length <= 100
password
包含字母,数字和"!@#$%^&*()-+"
这些特殊字符。
方法一:直接遍历判断
class Solution:
def strongPasswordCheckerII(self, password: str) -> bool:
if len(password) < 8:
return False
ans = 0
for i, c in enumerate(password):
if i and password[i - 1] == c:
return False
if c.islower():
ans |= 1
elif c.isupper():
ans |= 2
elif c.isdigit():
ans |= 4
else:
ans |= 8
return ans == 15
class Solution {
public boolean strongPasswordCheckerII(String password) {
if (password.length() < 8) {
return false;
}
int ans = 0;
char prev = '.';
for (char c : password.toCharArray()) {
if (prev == c) {
return false;
}
prev = c;
if (Character.isLowerCase(c)) {
ans |= 1;
} else if (Character.isUpperCase(c)) {
ans |= 2;
} else if (Character.isDigit(c)) {
ans |= 4;
} else {
ans |= 8;
}
}
return ans == 15;
}
}
class Solution {
public:
bool strongPasswordCheckerII(string password) {
if (password.size() < 8) return false;
int ans = 0;
char prev = '.';
for (char& c : password) {
if (c == prev) return false;
prev = c;
if (c >= 'a' && c <= 'z')
ans |= 1;
else if (c >= 'A' && c <= 'Z')
ans |= 2;
else if (c >= '0' && c <= '9')
ans |= 4;
else
ans |= 8;
}
return ans == 15;
}
};
func strongPasswordCheckerII(password string) bool {
if len(password) < 8 {
return false
}
ans := 0
for i, c := range password {
if i > 0 && password[i] == password[i-1] {
return false
}
if unicode.IsLower(c) {
ans |= 1
} else if unicode.IsUpper(c) {
ans |= 2
} else if unicode.IsDigit(c) {
ans |= 4
} else {
ans |= 8
}
}
return ans == 15
}
function strongPasswordCheckerII(password: string): boolean {
if (password.length < 8) return false;
if (!/[a-z]+/g.test(password)) return false;
if (!/[A-Z]+/g.test(password)) return false;
if (!/[0-9]+/g.test(password)) return false;
if (!/[\!\@\#\$\%\^\&\*\(\)\-\+]+/g.test(password)) return false;
const n = password.length;
for (let i = 1; i < n; i++) {
if (password.charAt(i) == password.charAt(i - 1)) return false;
}
return true;
}