算法/编程练习:强密码检测器

2024-09-04 18:32

本文主要是介绍算法/编程练习:强密码检测器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

强密码检测器


1. 题目

题目来自LeetCode:
https://leetcode-cn.com/problems/strong-password-checker/

题目:

一个强密码应满足3个条件:1)由至少6个,至多20个字符组成;2)至少包含一个小写字母,一个大写字母,和一个数字;3)同一字符不能连续出现三次 (比如'.aaa.'不可以,但'.aa.a.'是可以的)。
编写函数StrongPasswordChecker(s),s代表输入字符串,要求实现:如果s已经符合强密码条件,则返回0;否则返回要将s修改为满足强密码条件的字符串所需要进行修改的最小步数插入、删除、替换任一字符都算作一次替换)。

2. 思路:

如果缺失类型有Nmis种,则至少进行Nmis次操作(插入或替换),故Nmis为操作次数下界。如果长L度小于6,那么通过添加6-L个字符使密码合法
(因为最长长度是5,添加一个字符就可以打破连续三字符,所以不需要考虑连续),
结果应为max(6-L, Nmis)。如果L小于等于20,那么通过替换进行去连续。
一个长度为X的连续串,需要X//3次替换或X//2次插入或X-2次删除,所以不考虑插入和删除操作)。
记替换次数为Nrep,结果应为max(Nrep, Nmis)。如果L大于20,必须进行Ndel = L-20次删除操作,删除后还需要替换去除连续。
结果应为Ndel + max(Nrep, Nmis)。
在删除的时候应尽量删除连续字符以减少后续替换的数量。
连续子串的长度不一定是某个固定模式的:如果连续串长度是3n的形式,那么先删除1个字符,可以减少一次替换操作。如果连续串长度是3n+1的形式,那么先删除2个字符,可以减少一次替换操作。如果连续串长度是3n+2的形式,那么先删除3个字符,可以减少一次替换操作。可先将长度为3n和3n+1形式的重复子串进行删除操作,统一转化为3n+2形式。假设长度为3n形式的子串有del1个,可全部先删除一个字符,共减少del1次替换操作,Nrep变为Nrep - min(Ndel, del1)。假设长度为3n+1形式的子串有del2个,有必要先删除2个字符从而减少后续一次替换操作的子串个数应为min((Ndel-del1) // 2, del2)个(注:不一定所有的子串都需要进行先删除2个字符,比如'Aa0abcdefghiooookoooo',只需要替换不需要删除),从而Nrep变为Nrep - min((Ndel-del1) // 2, del2)。经过前两种情况的处理之后,所有需要删除的点中重复子串长度全部转化为3n+2形式。剩余删除点个数为Ndel-del1-2*del2,由于每删除3个点可以减少一次替换操作,故最多可减少的替换操作次数为(Ndel-del1-2*del2) // 3,从而Nrep变为Nrep - (Ndel-del1-2*del2) // 3。参考:https://leetcode-cn.com/problems/strong-password-checker/solution/shi-jian-onkong-jian-o10mssi-lu-by-jriver/https://leetcode-cn.com/problems/strong-password-checker/solution/si-lu-qing-xi-ban-yun-ban-ben-by-bakezq/

3. Python代码:

# -*- coding: utf-8 -*-import redef StrongPasswordChecker(s):L = len(s)# Nmis: 缺失类型数mis_a = 0 if re.search('[a-z]+', s) else 1mis_A = 0 if re.search('[A-Z]+', s) else 1mis_d = 0 if re.search('\d+', s) else 1Nmis = mis_a + mis_A + mis_ddel1, del2, Nrep = 0, 0, 0i = 2while i < L:# 若单个字符的最大重复次数超过3if s[i] == s[i-1] and s[i-1] == s[i-2]:# X记录最大重复次数X = 3            while i+1 < L and s[i+1] == s[i]:i += 1X += 1Nrep += X // 3 # 对重复字符串进行替换需要操作次数if X % 3 == 0:# 当重复次数为3n(n >= 1),提前删除一个字符可减少一次替换操作del1 += 1elif X % 3 == 1:# 当重复次数为3n+1(n >= 1),提前删除两个字符可减少一次替换操作del2 += 1i += 1if L < 6:# 当长度小于6时,不需要进行替换和删除操作,只需在适当位置插入缺失类型字符即可# (若有重复长度大于3的,只需要在中间插入打断其重复长度即可,如'aaaaa'—>'aaAaa0')return max(6-L, Nmis)elif L <= 20:# 当长度在20及以内时,由于删除和插入的效率小于等于替换,且效果相同,故不考虑删除操作# 缺失类型的插入操作均可用替换操作代替return max(Nrep, Nmis)else:Ndel = L-20 # 必须要进行的删除次数Nrep -= min(Ndel, del1) # 提前删除一个字符代替(减少)一次替换# 提前删除2个字符代替(减少)一次替换操作if Ndel - del1 > 0:Nrep -= min((Ndel-del1) // 2, del2)# 提前删除3个字符代替(减少)一次替换操作if Ndel-del1-2*del2 > 0:Nrep -= (Ndel-del1-2*del2) // 3return Ndel + max(Nrep, Nmis)if __name__ == '__main__':s = 'AAabc3'print(s+':')print(StrongPasswordChecker(s))s = 'aaaaa'print(s+':')print(StrongPasswordChecker(s))s='AAVAaBCD222'print(s+':')print(StrongPasswordChecker(s))s = ''print(s+':')print(StrongPasswordChecker(s))s = '1111111111'print(s+':')print(StrongPasswordChecker(s))

欢迎关注公众号:一本正经d胡说
Genlovy562

这篇关于算法/编程练习:强密码检测器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1136700

相关文章

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

Oracle登录时忘记用户名或密码该如何解决

《Oracle登录时忘记用户名或密码该如何解决》:本文主要介绍如何在Oracle12c中忘记用户名和密码时找回或重置用户账户信息,文中通过代码介绍的非常详细,对同样遇到这个问题的同学具有一定的参... 目录一、忘记账户:二、忘记密码:三、详细情况情况 1:1.1. 登录到数据库1.2. 查看当前用户信息1.

SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)

《SpringBoot使用Jasypt对YML文件配置内容加密的方法(数据库密码加密)》本文介绍了如何在SpringBoot项目中使用Jasypt对application.yml文件中的敏感信息(如数... 目录SpringBoot使用Jasypt对YML文件配置内容进行加密(例:数据库密码加密)前言一、J

MySQL9.0默认路径安装下重置root密码

《MySQL9.0默认路径安装下重置root密码》本文主要介绍了MySQL9.0默认路径安装下重置root密码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录问题描述环境描述解决方法正常模式下修改密码报错原因问题描述mysqlChina编程采用默认安装路径,

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

MySQL修改密码的四种实现方式

《MySQL修改密码的四种实现方式》文章主要介绍了如何使用命令行工具修改MySQL密码,包括使用`setpassword`命令和`mysqladmin`命令,此外,还详细描述了忘记密码时的处理方法,包... 目录mysql修改密码四种方式一、set password命令二、使用mysqladmin三、修改u

C#多线程编程中导致死锁的常见陷阱和避免方法

《C#多线程编程中导致死锁的常见陷阱和避免方法》在C#多线程编程中,死锁(Deadlock)是一种常见的、令人头疼的错误,死锁通常发生在多个线程试图获取多个资源的锁时,导致相互等待对方释放资源,最终形... 目录引言1. 什么是死锁?死锁的典型条件:2. 导致死锁的常见原因2.1 锁的顺序问题错误示例:不同

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo

PyCharm接入DeepSeek实现AI编程的操作流程

《PyCharm接入DeepSeek实现AI编程的操作流程》DeepSeek是一家专注于人工智能技术研发的公司,致力于开发高性能、低成本的AI模型,接下来,我们把DeepSeek接入到PyCharm中... 目录引言效果演示创建API key在PyCharm中下载Continue插件配置Continue引言