Java实现 LeetCode 420 强密码检验器
420. 强密码检验器
一个强密码应满足以下所有条件:
由至少6个,至多20个字符组成。
至少包含一个小写字母,一个大写字母,和一个数字。
同一字符不能连续出现三次 (比如 “…aaa…” 是不允许的, 但是 “…aa…a…” 是可以的)。
编写函数 strongPasswordChecker(s),s 代表输入字符串,如果 s 已经符合强密码条件,则返回0;否则返回要将 s 修改为满足强密码条件的字符串所需要进行修改的最小步数。
插入、删除、替换任一字符都算作一次修改。
PS:
这题真烦人
举例 aaaaa 五连字符,要正确的话如果只删除要 33 步,
如果插入的话要 22 步,如果替换只需要替换中间的 aa 一步就可以完成。
长度 <6 ,步数=缺失类型和缺失长度取大者。
长度 (6,20),这时候我们不需要低效的插入和删除来处理连续字符,直接替换步数就等于处理连续字和缺失类型取大者。
比较负载的是 >20,我们需要知道优先级,一样优先处理连续数组。
优先处理缺失类型,用替换的方式来处理,这时候要替换的连续组的连续数 %3==2 -> 连续数%3==1 -> 连续数%3==0,然后处理多余字符,删除的优先级是连续组的连续数 %3==0 -> 连续数%3==1 -> 连续数%3==2
class Solution {
/**
* 记录连续出现的字符 起始和终止坐标
*/
class SameChar {
int st;
int en;
char c;
SameChar(int st, int en, char c) {
this.st = st;
this.en = en;
this.c = c;
}
}
public int strongPasswordChecker(String str) {
// 统计小写字符
int lowerCase = 0;
// 统计大写字符
int upwerCase = 0;
// 统计数字
int number = 0;
// 统计连续字符出现的位置
java.util.ArrayList<SameChar> sameChars = new java.util.ArrayList<SameChar>();
char[] chars = str.toCharArray();
if (chars.length == 0) {
return 6;
}
// 记露连续出现的字符
SameChar sameChar = new SameChar(0, 0, '\0');
for (int i = 0; i < chars.length; i++) {
if (chars[i] >= 'a' && chars[i] <= 'z') {
lowerCase++;
} else if (chars[i] >= 'A' && chars[i] <= 'Z') {
upwerCase++;
} else if (chars[i] >= '0' && chars[i] <= '9') {
number++;
}
if (sameChar.c != chars[i]) {
if (sameChar.en - sameChar.st >= 2) {
sameChars.add(new SameChar(sameChar.st, sameChar.en, sameChar.c));
}
sameChar.c = chars[i];
sameChar.st = i;
sameChar.en = i;
} else {
sameChar.en = i;
}
}
if (sameChar.en - sameChar.st >= 2) {
sameChars.add(new SameChar(sameChar.st, sameChar.en, sameChar.c));
}
// 缺失的类型. 只可能是1 or 2
int needType = count0(lowerCase, upwerCase, number);
// 连续的字符出现的要消除的个数 连续值-2
int[] chages = new int[sameChars.size()];
for (int j = 0; j < sameChars.size(); j++) {
chages[j] = sameChars.get(j).en - sameChars.get(j).st - 1;
}
int res = 0;
// 如果长度小于6 , 很简单 要补的字符和缺失的类型择大
if (str.length() < 6) {
return Integer.max(6 - str.length(), needType);
}
// 删除的时候 要有优先概念
if (str.length() > 20) {
int index = -1;
while (needType > 0 && (index = find(chages, 0)) > -1) {
chages[index] = Integer.max(chages[index] - 3, 0);
res++;
needType--;
}
int d = str.length() - 20;
while (d > 0 && (index = find(chages, 1)) > -1) {
d--;
res++;
chages[index]--;
}
int n = 0;
for (int l = 0; l < chages.length; l++) {
n += chages[l] % 3 == 0 ? chages[l] / 3 : chages[l] / 3 + 1;
}
return res + d + needType + n;
}
int n = 0;
for (int l = 0; l < chages.length; l++) {
n += chages[l] % 3 == 0 ? chages[l] / 3 : chages[l] / 3 + 1;
}
return Integer.max(n, needType);
}
private int count0(int... array) {
int n = 0;
for (int i = 0; i < array.length; i++) {
if (array[i] == 0) {
n++;
}
}
return n;
}
private int find(int[] array, int n) {
int n0 = -1;
int n1 = -1;
int n2 = -1;
for (int i = 0; i < array.length; i++) {
if (array[i] > 0 && array[i] % 3 == 0) {
n0 = i;
}
if (array[i] > 0 && array[i] % 3 == 1) {
n1 = i;
}
if (array[i] > 0 && array[i] % 3 == 2) {
n2 = i;
}
}
if (n == 0) {
return n0 > -1 ? n0 : (n2 > -1 ? n2 : n1);
}
if (n == 1) {
return n1 > -1 ? n1 : (n2 > -1 ? n2 : n0);
}
return -1;
}
}
Java实现 LeetCode 420 强密码检验器的更多相关文章
- [Swift]LeetCode420. 强密码检验器 | Strong Password Checker
A password is considered strong if below conditions are all met: It has at least 6 characters and at ...
- Java实现7种常见密码算法
原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介 前面在密码学入门一文中讲解了各种常见的密码学概念.算法与运用场景,但没有介绍过代码,因此,为作补充,这一篇将会介绍 ...
- Java for LeetCode 216 Combination Sum III
Find all possible combinations of k numbers that add up to a number n, given that only numbers from ...
- Java for LeetCode 214 Shortest Palindrome
Given a string S, you are allowed to convert it to a palindrome by adding characters in front of it. ...
- Java for LeetCode 212 Word Search II
Given a 2D board and a list of words from the dictionary, find all words in the board. Each word mus ...
- Java for LeetCode 211 Add and Search Word - Data structure design
Design a data structure that supports the following two operations: void addWord(word)bool search(wo ...
- Java for LeetCode 210 Course Schedule II
There are a total of n courses you have to take, labeled from 0 to n - 1. Some courses may have prer ...
- mysql root强密码的必要性max_allowed_packet被改成1024引起的风险
前两天运维反馈说,有些机器的max_allowed_packet隔两天就会被改成1024,导致客户端调用时出错,网上有说内存不够的,也有人工修改的. 运维小姑娘一口咬定肯定没有改过的,而且my.cnf ...
- Java for LeetCode 200 Number of Islands
Given a 2d grid map of '1's (land) and '0's (water), count the number of islands. An island is surro ...
随机推荐
- SORM框架01
架构图 Query接口:负责查询(对外提供的核心服务类) QueryFactory类:负责根据配置信息创建Query对象 TypeConvertor接口:类型转换 TableContext类:负责获取 ...
- Mysql常用sql语句(21)- regexp 正则表达式查询
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 正则的强大不言而喻,Mysql中也提供了 reg ...
- linux --文件目录的学习
https://www.runoob.com/linux/linux-file-content-manage.html /boot:存放的启动Linux 时使用的内核文件,包括连接文件以及镜像文件. ...
- OpenCV开发笔记(五十六):红胖子8分钟带你深入了解多种图形拟合逼近轮廓(图文并茂+浅显易懂+程序源码)
若该文为原创文章,未经允许不得转载原博主博客地址:https://blog.csdn.net/qq21497936原博主博客导航:https://blog.csdn.net/qq21497936/ar ...
- Win10最常用的快捷键,效率Max提高100%(常用的应该是最全的)
写在最前面 这是博主爆肝了一晚上给写出来,因为很多博客和资料中仍然使用的xp win7 和win8 的快捷键,我不断地的实验和尝试,总结出以下的快捷键,希望可以帮助到你. 最后,未经运营,爆肝博文不得 ...
- Spring Boot 使用 JSR303 实现参数验证
简介 JSR-303 是 JAVA EE 6 中的一项子规范,叫做 Bean Validation. 在任何时候,当你要处理一个应用程序的业务逻辑,数据校验是你必须要考虑和面对的事情.应用程序必须通过 ...
- 2.1Go语言特性
1.1.2. 编程语言类型 静态语言,动态语言 静态语言:强类型语言 定义变量,必须指明数据类型,存储对应类型的数据. 例如java,go,c 动态语言:弱类型语言 定义变量,赋值过程决定 ...
- Storm-jdbc-2讲 高级API及Trident
之前对Storm集成JDBC写了一个简单的demo,最近深度研究了下,代码如下 首先,先写一个抽象类,便于减少代码的重复性: import com.google.common.collect.List ...
- Excel导出到DataSet
#region 导入excel 返回Dataset public DataSet ExecleDataSet(string filename, string file, string Type) { ...
- 存储系列之 Linux ext2 概述
引言:学习经典永不过时. 我们之前介绍过存储介质主要是磁盘,先介绍过物理的,后又介绍了虚拟的.保存在磁盘上的信息一般采用文件(file)为单位,磁盘上的文件必须是持久的,同时文件是通过操作系统管理的, ...