【贪心]【字符串】【分类讨论】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++**实现。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

SQL Server 存储过程——SQL Server 储存过程的创建与使用

任务描述 本关任务&#xff1a;学习 SQL Server 中存储过程的创建和使用。 相关知识 存储过程提供了很多 T-SQL 语言没有的高级特性&#xff0c;其传递参数和执行逻辑的能力&#xff0c;为处理各种复杂任务提供了支持。并且&#xff0c;由于存储过程是经过编译后&#xff0c…

云手机:实现便携与安全的双赢

随着5G时代的到来&#xff0c;云手机在各大游戏、直播和新媒体营销中扮演越来越重要的角色。它不仅节约了成本&#xff0c;提高了效率&#xff0c;而且在边缘计算和云技术逐渐成熟的背景下&#xff0c;展现出了更大的发展机遇。 云手机的便携性如何&#xff1f; 云手机的便携性…

奇偶校验|ECC内存|海明码

前言 大家好&#xff0c;我是jiantaoyab&#xff0c;本篇文章给大家介绍数据出错和有什么方法能减少出错。 单比特翻转 由于硬件故障或其他原因&#xff0c;内存或其他存储设备中的单个比特位发生随机变化的现象。 例如&#xff0c;原本存储为1的位可能变为0&#xff0c;或…

Git入门(Git快速下载,安装,配置,远程仓库,本地仓库,IDEA提交代码,VScode提交代码使用方案一体)

Git快速下载 通过阿里镜像可以自由挑选版本并快速下载CNPM Binaries Mirrorhttp://npm.taobao.org/mirrors/git-for-windows/ 这里安装最新版本 下载安装文件 安装完后双击文件即可开始安装git 安装 git的安装傻瓜式Next即可 配置 打开git&#xff1a;桌面空白处右击&#…

雷卯推荐多种系列汽车级TVS供您选择

1. 车规级TVS的应用 2.车规级TVS系列表格如下 3.方案推荐 12V汽车电源浪涌保护方案 方案优点&#xff1a;用于满足前装汽车的ISO7637-2 5A5BA测试&#xff0c;可采用单独大功率的TVS或PTCTVS的组合方案&#xff0c;满足ISO10605-2&#xff0c; 等级4&#xff0c;接触放电15K…

Python包管理工具 pip 及其常用命令和参数用法

目录 PIP 主要功能 安装包 升级包 卸载包 列出包 检查依赖 pip的配置和环境 主要用法 1&#xff1a;版本 2&#xff1a;安装 Python 库 3&#xff1a;升级库 4&#xff1a;卸载库 5&#xff1a;搜索库 6&#xff1a;查看已安装库详细信息 7&#xff1a;只下载库…

[CISCN2019 华东北赛区]Web2

[CISCN2019 华东北赛区]Web2 随便注册一个登录&#xff0c;发现 还有反馈页面&#xff0c;一看就知道大概率是xss&#xff0c;应该是为了得到管理员cookie扫描了一下&#xff0c;果然有admin.php后台登录 buu可以连接访问外网了&#xff0c;所以内部的xss平台关闭了&#xff0…

2014年认证杯SPSSPRO杯数学建模A题(第一阶段)轮胎的花纹全过程文档及程序

2014年认证杯SPSSPRO杯数学建模 A题 轮胎的花纹 原题再现&#xff1a; 轮胎被广泛使用在多种陆地交通工具上。根据性能的需要&#xff0c;轮胎表面常会加工出不同形状的花纹。在设计轮胎时&#xff0c;往往要针对其使用环境&#xff0c;设计出相应的花纹形状。   第一阶段问…

前端日期组件layui使用,月模式

初学前端&#xff0c;实战总结 概要 有一个日期组件&#xff0c;我的谷歌浏览器选完日期后&#xff0c;偶尔获取不到最新数据&#xff0c;有一个客户&#xff0c;是经常出不来数据。 日期组件是Wdate&#xff1a;调用的方法是WdatePicker onpicking&#xff0c;代码片段如下…

Apple Vision Pro应用合集

这里给大家分享一个网站&#xff0c;手机了最新的apple vision pro 上面运行的应用。 1、查找应用&#xff1a;用户可以浏览特色推荐的应用&#xff0c;或者通过随机挑选功能发现新的应用。 2、社区交流&#xff1a;提供社区功能&#xff0c;用户可以在这里交流使用体验、分享…

燃气官网安全运行监测系统-阀井燃气监测仪-旭华智能

近年来&#xff0c;燃气爆炸事故频发&#xff0c;造成了重大人员伤亡和财产损失。这也再次为我们敲响警钟&#xff0c;燃气是我们日常生活中不可或缺的能源&#xff0c;但其潜在的危险性也是不容小觑。因此在重要节点加装燃气阀井气体监测仪&#xff0c;并将数据上传到系统平台…

【网安小白成长之路】1.PHP基本语法

&#x1f42e;博主syst1m 带你 acquire knowledge&#xff01; ✨博客首页——syst1m的博客&#x1f498; &#x1f51e; 《网安小白成长之路(我要变成大佬&#x1f60e;&#xff01;&#xff01;)》真实小白学习历程&#xff0c;手把手带你一起从入门到入狱&#x1f6ad; &…

Spring Cloud 九:服务间通信与消息队列

Spring Cloud 一&#xff1a;Spring Cloud 简介 Spring Cloud 二&#xff1a;核心组件解析 Spring Cloud 三&#xff1a;API网关深入探索与实战应用 Spring Cloud 四&#xff1a;微服务治理与安全 Spring Cloud 五&#xff1a;Spring Cloud与持续集成/持续部署&#xff08;CI/C…

Git学习(一)基于本地操作:Git初识、Git安装(Linux-ubuntu)、Git 基本操作、分支管理

目录 Git 初识 Git 安装&#xff08;Linux-ubuntu&#xff09; Git 基本操作 创建 Git 本地仓库 配置 Git 认识工作区、暂存区、版本库 添加文件 查看 .git 文件 修改文件 版本回退 撤销修改 情况一&#xff1a;对于工作区的代码&#xff0c;还没有 add 情况二&am…

docker拉取镜像

docker 拉取镜像 命令格式 docker pull 仓库名称[:标签] 从下载过程可以看出&#xff1a; &#xff08;1&#xff09;镜像文件是由若干层组成&#xff0c;即&#xff1a;AUFS联合文件系统。这是实现增量保存与更新的基础 &#xff08;2&#xff09;下载过程会输出各层镜像的信…

博客系统——1、数据库表设计 - 用户信息表

任务描述 本关任务&#xff1a;创建博客系统数据库的用户信息表。 相关知识 数据库整体设计 一个博客系统会有哪些功能呢&#xff0c;肯定会有的是博客列表&#xff0c;博客详情&#xff0c;评论&#xff0c;登陆注册等等这些功能&#xff0c;那应该建多少张表呢&#xff1…

《机器学习:引领数字化时代的技术革命》

随着科技的不断发展&#xff0c;机器学习作为人工智能的重要支柱之一&#xff0c;正迅速崛起并引领着数字化时代的技术革命。本文将从机器学习的技术进展、技术原理、行业应用案例、面临的挑战与机遇以及未来趋势预测和学习路线等方面展开探讨&#xff0c;为您揭示机器学习的神…

PC电脑技巧[笔记本通过网线访问设备CMW500]

笔记本局域网访问设备 现在我有一台CMW500,我要用笔记本去访问它,但是我发现没有路由器就是不能够访问,通过网线连接设备就是ping不通: 这里设置TCP/IPv4的IP地址如下,这时候就可以pin通了:

VOC(客户之声)赋能智能家居:打造个性化、交互式的未来生活体验

随着科技的飞速发展&#xff0c;智能家居已成为现代家庭不可或缺的一部分。然而&#xff0c;如何让智能家居更好地满足用户需求&#xff0c;提供更贴心、更智能的服务&#xff0c;一直是行业关注的焦点。在这个背景下&#xff0c;VOC&#xff08;客户之声&#xff09;作为一种用…

分类预测 | Matlab实现CNN-BiLSTM-Mutilhead-Attention卷积双向长短期记忆网络多头注意力机制多特征分类预测

分类预测 | Matlab实现CNN-BiLSTM-Mutilhead-Attention卷积双向长短期记忆网络多头注意力机制多特征分类预测 目录 分类预测 | Matlab实现CNN-BiLSTM-Mutilhead-Attention卷积双向长短期记忆网络多头注意力机制多特征分类预测分类效果基本介绍模型描述程序设计参考资料 分类效果…