「每日LeetCode」2022年8月23日

本文最后更新于:2023年3月19日 晚上

2299.强密码检验器 II

2299.强密码检验器 II

Category Difficulty Likes Dislikes
algorithms Easy (62.48%) 6 -

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

  • 它有至少 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 包含字母,数字和 “!@#$%^&*()-+” 这些特殊字符。

Discussion | Solution

思路

按题意模拟即可

解答

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/*
* @lc app=leetcode.cn id=2299 lang=javascript
*
* [2299] 强密码检验器 II
*/

// @lc code=start
/**
* @param {string} password
* @return {boolean}
*/
var strongPasswordCheckerII = function (password) {
if (password.length < 8) return false;
const reg1 = /[a-z]/,
reg2 = /[A-Z]/,
reg3 = /[0-9]/,
reg4 = /[\!\@\#\$\%\^\&\*\(\)\-\+]/;
let prev;
let hasLower = false,
hasUpper = false,
hasNum = false,
hasString = false;
for (const char of password) {
if (prev === char) return false;
prev = char;
if (reg1.test(char)) hasLower = true;
else if (reg2.test(char)) hasUpper = true;
else if (reg3.test(char)) hasNum = true;
else if (reg4.test(char)) hasString = true;
}
return hasLower && hasUpper && hasNum && hasString;
};
// @lc code=end