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

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

相关文章

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

Python从零打造高安全密码管理器

《Python从零打造高安全密码管理器》在数字化时代,每人平均需要管理近百个账号密码,本文将带大家深入剖析一个基于Python的高安全性密码管理器实现方案,感兴趣的小伙伴可以参考一下... 目录一、前言:为什么我们需要专属密码管理器二、系统架构设计2.1 安全加密体系2.2 密码强度策略三、核心功能实现详解

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

揭秘Python Socket网络编程的7种硬核用法

《揭秘PythonSocket网络编程的7种硬核用法》Socket不仅能做聊天室,还能干一大堆硬核操作,这篇文章就带大家看看Python网络编程的7种超实用玩法,感兴趣的小伙伴可以跟随小编一起... 目录1.端口扫描器:探测开放端口2.简易 HTTP 服务器:10 秒搭个网页3.局域网游戏:多人联机对战4.

Java并发编程必备之Synchronized关键字深入解析

《Java并发编程必备之Synchronized关键字深入解析》本文我们深入探索了Java中的Synchronized关键字,包括其互斥性和可重入性的特性,文章详细介绍了Synchronized的三种... 目录一、前言二、Synchronized关键字2.1 Synchronized的特性1. 互斥2.

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Python异步编程中asyncio.gather的并发控制详解

《Python异步编程中asyncio.gather的并发控制详解》在Python异步编程生态中,asyncio.gather是并发任务调度的核心工具,本文将通过实际场景和代码示例,展示如何结合信号量... 目录一、asyncio.gather的原始行为解析二、信号量控制法:给并发装上"节流阀"三、进阶控制

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth