【贪心]【字符串】【分类讨论】420 强密码检验器

本文涉及知识点

贪心 字符串 分类讨论

LeetCode420 强密码检验器

满足以下条件的密码被认为是强密码:
由至少 6 个,至多 20 个字符组成。
包含至少 一个小写 字母,至少 一个大写 字母,和至少 一个数字 。
不包含连续三个重复字符 (比如 “Baaabb0” 是弱密码, 但是 “Baaba0” 是强密码)。
给你一个字符串 password ,返回 将 password 修改到满足强密码条件需要的最少修改步数。如果 password 已经是强密码,则返回 0 。
在一步修改操作中,你可以:
插入一个字符到 password ,
从 password 中删除一个字符,或
用另一个字符来替换 password 中的某个字符。
示例 1:
输入:password = “a”
输出:5
示例 2:
输入:password = “aA1”
输出:3
示例 3:
输入:password = “1337C0d3”
输出:0

提示:
1 <= password.length <= 50
password 由字母、数字、点 ‘.’ 或者感叹号 ‘!’ 组成

分类讨论

n = password.length
问题一:字符少于6个。 只能增加。
问题二:字符多余20个。只能删除。
问题三:缺少大写字母、小写字母、数字。编辑或增加,效率一样。
问题三:连续相同字符。编辑的效率最高,插入其次,删除最次。

n < 6

只需要增加,不需要删除和编辑。
3,4个连续相同字符,增加和编辑效率一样。
5个连续字符,两种方案:一,增加2次。二,编辑一次,增加一次。效率一样。

n ∈ \in [6,20]

只需要编辑,不需要增加和删除。

n > 20

不需要增加,增加用编辑代替。
i2= n -20。 处理问题4,至少删除i2次。如果存在3的倍数,删除可以减少用编辑处理问题四的次数。没有3的倍数, % \% % 3 为1的,减少2;否则 % \% % 3 为2的,减少3。
i3 记录缺少的字符类型数量。可以和问题一同处理。

代码

核心代码

class Solution {
public:int strongPasswordChecker(string password) {m_c = password.length();const int i1 = max(0,6 - m_c);const int i2 = max(0, m_c - 20);unordered_set<int> setType;for (const auto& ch : password){if (islower(ch)){setType.emplace(1);}if (isupper(ch)){setType.emplace(2);}if (isdigit(ch)){setType.emplace(3);}}priority_queue<pair<int, int>,vector<pair<int, int>>,std::greater<>> minHeap;int preIndex = 0;auto Add = [&](const int len){	if (len  < 3){return;}minHeap.emplace(len % 3+1, len);};auto Total = [&minHeap](){int iRet = 0;while (minHeap.size()){iRet += minHeap.top().second / 3;minHeap.pop();}return iRet;};const int i3 = 3 - setType.size();for (int i = 1; i < m_c; i++){if (password[preIndex] != password[i]){Add( i - preIndex);preIndex = i ;}		}Add(m_c - preIndex);if (i1 > 0){int i4 = 0;if (minHeap.size() && (minHeap.top().second >= 3)){i4++;}if (minHeap.size() && (minHeap.top().second >= 5)){i4++;}return max(max(i1, i3), i4);}if (i2 > 0){int del = i2;while (minHeap.size() && (del >= minHeap.top().first)){del -= minHeap.top().first;const int len = minHeap.top().second - minHeap.top().first;minHeap.pop();Add(len);}return i2 + max(Total(), i3);}return max(i3, Total());}int m_c;
};

测试用例


template<class T,class T2>
void Assert(const T& t1, const T2& t2)
{assert(t1 == t2);
}template<class T>
void Assert(const vector<T>& v1, const vector<T>& v2)
{if (v1.size() != v2.size()){assert(false);return;}for (int i = 0; i < v1.size(); i++){Assert(v1[i], v2[i]);}}int main()
{vector<int> nums1, nums2;{Solution sln;;auto res = sln.strongPasswordChecker("aaa111");Assert(2, res);}{Solution sln;;auto res = sln.strongPasswordChecker("aA123");Assert(1, res);}{Solution sln;;auto res = sln.strongPasswordChecker("a");Assert(5, res);}{Solution sln;;auto res = sln.strongPasswordChecker( "aA1");Assert(3, res);}{Solution sln;;auto res = sln.strongPasswordChecker("1337C0d3");Assert(0, res);}
}

2023年5月

class Solution {
public:
int strongPasswordChecker(string password) {
Init(password);
if (m_c < 6)
{//插入一定由于其它两种
int iInsertForRepeat = 0;
for (const auto& it : m_setRepeatNum)
{
iInsertForRepeat += (it>=5)?2:1;
}
return max(max(6 - m_c, 3 - m_iTypeNum), iInsertForRepeat);
}
else if (m_c > 20)
{//对应条件1,条件3,修改优化插入;条件2,相同。所以,淘汰插入
//条件1只能删除,条件2只能修改
//3字符重复,删除一个字符,可以减少一次修改,6,9 …字符重复也是
//4字符重复,需要删除2个字符,才能减少一次修改次数,7,10…也是
//5字符重复,需要删除3个字符…
int iDoLen = m_c - 20;
const int iDoType = 3 - m_iTypeNum;
int iNeedDo = iDoLen + iDoType;
Do(iDoLen, 0);
Do(iDoLen, 1);
while ((iDoLen >= 3) && m_setRepeatNum.size())
{
Do(iDoLen, 2);
}
int iReplaceForRepeat = 0;
for (const auto& it : m_setRepeatNum)
{
iReplaceForRepeat += it / 3;
}
return iNeedDo + max(0, iReplaceForRepeat - iDoType);
}
else
{//替换字符一定优化其它两种
int iReplaceForRepeat = 0;
for (const auto& it : m_setRepeatNum)
{
iReplaceForRepeat += it /3 ;
}
return max(iReplaceForRepeat, 3 - m_iTypeNum);
}
}
void Do(int& iDoLen,int iMod)
{
std::unordered_multiset tmp;
for (auto& it : m_setRepeatNum )
{
if (iDoLen >= iMod+1)
{
if (iMod == it % 3)
{
iDoLen -= (iMod + 1);
const int iNewRepeatNum = it - (iMod + 1);
if (iNewRepeatNum >= 3)
{
tmp.insert(iNewRepeatNum);
}
continue;
}
}
tmp.insert(it);
}
m_setRepeatNum.swap(tmp);
}
void Init(const string& password)
{
m_c = password.length();
char preChar = 0;
int iRepeatNum = 0;
for (int i = 0; i < m_c; i++)
{
const char& ch = password[i];
if (ch == preChar)
{
iRepeatNum++;
}
else
{
if (iRepeatNum >= 3)
{
m_setRepeatNum.insert(iRepeatNum);
}
iRepeatNum = 1;
preChar = ch;
}
m_iAZNum += (ch >= ‘A’) && (ch <= ‘Z’);
m_iazNum += (ch >= ‘a’) && (ch <= ‘z’);
m_iDigNum += (ch >= ‘0’) && (ch <= ‘9’);
}
if (iRepeatNum >= 3)
{
m_setRepeatNum.insert(iRepeatNum);
}
m_iTypeNum += (m_iAZNum > 0) + (m_iazNum > 0) + (m_iDigNum > 0);
}
int m_c = 0;
int m_iTypeNum = 0;
int m_iAZNum = 0;
int m_iazNum = 0;
int m_iDigNum = 0;
std::unordered_multiset m_setRepeatNum;// 重复i次的字符
};

扩展阅读

视频课程

有效学习:明确的目标 及时的反馈 拉伸区(难度合适),可以先学简单的课程,请移步CSDN学院,听白银讲师(也就是鄙人)的讲解。
https://edu.csdn.net/course/detail/38771

如何你想快速形成战斗了,为老板分忧,请学习C#入职培训、C++入职培训等课程
https://edu.csdn.net/lecturer/6176

相关

下载

想高屋建瓴的学习算法,请下载《喜缺全书算法册》doc版
https://download.csdn.net/download/he_zhidan/88348653

我想对大家说的话
闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。
子墨子言之:事无终始,无务多业。也就是我们常说的专业的人做专业的事。
如果程序是一条龙,那算法就是他的是睛

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17
如无特殊说明,本算法用**C++**实现。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/773304.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Reactor 模式全解:实现非阻塞 I/O 多路复用

Reactor网络模式是什么&#xff1f; Reactor网络模式时目前网络最常用的网络模式。如果你使用Netty&#xff0c;那么你在使用Reactor;如果你使用Twisted,那么你子啊使用Reactor;如果你使用netpoll&#xff0c;那么你在使用Reactor。 这里先给出答案&#xff1a;Reactor I/O多…

204基于matlab的图像融合

基于matlab的图像融合&#xff0c;包括三种方式&#xff0c;加权、PCA、IHS变换。比较三者融合后的图像差异。程序已调通&#xff0c;可直接运行。 204 matlab 图像融合 信息融合 - 小红书 (xiaohongshu.com)

【二叉树】Leetcode 94. 二叉树的中序遍历【简单】

二叉树的中序遍历 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,3,2] 解题思路 中序遍历是一种二叉树遍历方式&#xff0c;按照“左根右”的顺序遍历二叉树节点。 1、递归…

python 处理png图片无损压缩

代码利用了Pillow库来处理图片的压缩&#xff0c;并使用了 glob 模块来搜索所有的 .png 文件。这个脚本应该能够按照当前的编写来完成预期的工作。 请注意&#xff0c;compress_level9 指定了Pillow保存PNG图片时采用的最大压缩等级。这确保了每张图片都被以可能的最小文件大小…

【Spring】Spring框架中的一个核心接口ApplicationContext 简介,以及入口 Run() 的源码分析

一、简介 ApplicationContext 是Spring框架中的一个核心接口&#xff0c;它是Spring IoC容器的实现之一&#xff0c;用于管理和组织应用程序中的各种Bean&#xff0c;同时提供了一系列功能来支持依赖注入、AOP等特性。 简单来说&#xff0c;ApplicationContext 是一个大型的、…

求两个单链表的差集

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 但行前路&#xff0c;不负韶华&#…

发车,易安联签约某新能源汽车领军品牌,为科技创新保驾护航

近日&#xff0c;易安联成功签约某新能源汽车领军品牌&#xff0c;为其 数十万终端用户 建立一个全新的 安全、便捷、高效一体化的零信任终端安全办公平台。 随着新能源汽车行业的高速发展&#xff0c;战略布局的不断扩大&#xff0c;技术创新不断引领其市场价值走向高点&am…

移动端Web笔记day03

移动 Web 第三题 01-移动 Web 基础 谷歌模拟器 模拟移动设备&#xff0c;方便查看页面效果&#xff0c;移动端的效果是当手机屏幕发生了变化&#xff0c;页面和页面中的元素也要跟着等比例变化。 屏幕分辨率 分类&#xff1a; 硬件分辨路 -> 物理分辨率&#xff1a;硬件…

GTC 2024 火线评论:DPU 重构文件存储访问

编者按&#xff1a;英伟达2024 GTC 大会上周在美国加州召开&#xff0c;星辰天合 CTO 王豪迈在大会现场参与了 GPU 与存储相关的最新技术讨论&#xff0c;继上一篇《GTC 2024 火线评论&#xff1a;GPU 的高效存储利用》之后&#xff0c;这是他发回的第二篇评论文章。 上一篇文章…

pear-admin 项目结构讲解

上一篇文章介绍了pear-admin用到flask的技术&#xff0c; 深入代码后发现其结构也是令人眼前一亮&#xff0c; 结构化&#xff0c;模块化&#xff0c; 解耦做得非常优秀。 整个项目数据库使用migrate做了版本管理&#xff0c; 使用marshmallow做了序列化&#xff0c;这样数据库…

vue实现文字一个字一个字的显示(开箱即用)

图示&#xff1a; 核心代码 Vue.prototype.$showHtml function (str, haveCallback null) {let timeFlag let abcStr for (let i 0; i < str.length; i) {(function (i) {timeFlag setTimeout(function () {abcStr str[i]haveCallback(abcStr)if ((i 1) str.length…

EPSON推出的实时时钟模块RX8130CE功耗低至300nA、从容应对各种使用场景

随着科技的进步和消费者需求的不断变化&#xff0c;笔记本电脑市场继续展现出强劲的发展势头一方面移动性和轻薄性成为主流&#xff0c;另外一方面性能在不断提升&#xff0c;功能也日益丰富。实时时钟模组&#xff0c;作为提供时间和定时功能的单元模块&#xff0c;是笔记本电…

解决错误LibreSSL SSL_connect: SSL_ERROR_SYSCALL in connection to

react native pod第三方包或者git clone的时候遇到 OpenSSL SSL_connect: SSL_ERROR_SYSCALL in connection to github.com:443两种解决方案 方法一 修改计算机网络配置 由于使用 IPv6 的原因&#xff0c;可能会导致这一问题的出现 系统在解析hostname时使用了ipv6 可以配…

【工具】秘塔AI搜索|强烈推荐,中文免费搜索神器!堪比做报表的员工

网址&#xff1a;https://metaso.cn/ 使用时间&#xff1a;2024/03/27 以前其实用过它家的秘塔写作猫&#xff0c;当时感觉非常不错。 这次看到它出AI搜索&#xff0c;感觉开发者挺有野心和实力的。 推荐原因&#xff1a; 国产产品&#xff0c;中文适用性强。目前还免费。【不…

工业镜头常用参数之实效F(Fno.)和像圈

Fno. 工业镜头中常用到的参数F&#xff0c;有时候用F/#&#xff0c;Fno.来表示&#xff0c;指的是镜头通光能力的参数。它可用镜头焦距及入瞳直径来表示&#xff0c;也可通过镜头数值孔径&#xff08;NA&#xff09;和光学放大倍率&#xff08;β&#xff09;来计算。有效Fno.…

IDEA使用常用的设置

一、IDEA常用设置 可参考&#xff1a;IDEA这样配置太香了_哔哩哔哩_bilibili 波波老师 二、插件 可参考&#xff1a;IDEA好用插件&#xff0c;强烈推荐_哔哩哔哩_bilibili 波波老师 三、其他 学会用点“.” IDEA弹窗Servers certificate is not trusted怎么禁止&#xf…

计算机视觉之三维重建(4)---三维重建基础与极几何

文章目录 一、三维重建基础1.1 问题引入1.2 线性解法1.3 非线性解法1.4 多视图几何的关键问题 二、极几何与基础矩阵2.1 极几何2.2 极几何特例2.3 本质矩阵2.4 本质矩阵的性质2.5 基础矩阵2.6 基础矩阵的性质 三、基础矩阵估计 一、三维重建基础 1.1 问题引入 1. 从单张图像恢…

ROS机器人入门第四课:话题通信

文章目录 ROS机器人入门第四课&#xff1a;话题通信一、话题通信概述&#xff08;一&#xff09;概念&#xff08;二&#xff09;作用 二、话题通信基本操作需求:分析:流程:&#xff08;一&#xff09;发布方解释一些关键的ROS函数和概念&#xff1a; &#xff08;二&#xff0…

QT+Opencv+yolov5实现监测

功能说明&#xff1a;使用QTOpencvyolov5实现监测 仓库链接&#xff1a;https://gitee.com/wangyoujie11/qt_yolov5.git git本仓库到本地 一、环境配置 1.opencv配置 将OpenCV-MinGW-Build-OpenCV-4.5.2-x64文件夹放在自己的一个目录下&#xff0c;如我的路径&#xff1a; …

Spark SQL— Catalyst 优化器

Spark SQL— Catalyst 优化器 1. 目的 本文的目标是描述Spark SQL 优化框架以及它如何允许开发人员用很少的代码行表达复杂的查询转换。我们还将描述Spark SQL如何通过大幅提高其查询优化能力来提高查询的执行时间。在本教程中&#xff0c;我们还将介绍什么是优化、为什么使用…