如果一个密码满足以下所有条件,我们称它是一个 强 密码:
它有至少 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 包含字母,数字和 “!@#$%^&*()-+” 这些特殊字符。
public boolean strongPasswordCheckerII(String password) {
        int n = password.length();
        if (n<8){
            return false;
        }
        int[] arr = new int[4];
        for (int i = 0; i < n; i++) {
            char c = password.charAt(i);
            if (i>0&&password.charAt(i-1)==c){
                return false;
            }
            if (c>='a'&&c<='z'){
                arr[0]++;
            }else if (c>='A'&&c<='Z'){
                arr[1]++;
            }else if (c>='0'&&c<='9'){
                arr[2]++;
            }else if (c>='!'||c<='@'||c<='#'||c<='$'||
                    c>='%'||c<='^'||c<='&'||c<='*'||
                    c>='('||c<=')'||c<='-'||c<='+'){
                arr[3]++;
            }
        }
        return arr[0]*arr[1]*arr[2]*arr[3]>0;
    }

func strongPasswordCheckerII(password string) bool {
	n := len(password)
	if n<8 {
		return false
	}
	arr :=[4]int{0,0,0,0}
	for i := 0; i < n;i++{
		c := password[i]
		if i>0&&password[i-1]==c{
			return false
		}
		if c>='a'&&c<='z'{
			arr[0]++;
		}else if c>='A'&&c<='Z'{
			arr[1]++;
		}else if c>='0'&&c<='9'{
			arr[2]++
		}else if c>='!'||c<='@'||c<='#'||c<='$'||
			c>='%'||c<='^'||c<='&'||c<='*'||
			c>='('||c<=')'||c<='-'||c<='+'{
			arr[3]++
		}
	}
	return arr[0]*arr[1]*arr[2]*arr[3]>0
}
















![[标准库]STM32F103R8T6 串口的收发](https://img-blog.csdnimg.cn/cf35635de1df4f54a2b914f2c95666ff.png)



