密码验证合格程序(20200224)

该博客介绍了一个Python程序,用于验证密码是否符合特定要求:长度超过8位,包含大小写字母、数字和符号中的至少三种,并且不能有长度超过2的子串重复。博主分享了使用正则表达式的思路和代码实现,并鼓励读者提供优化方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目描述

密码要求:
1.长度超过8位
2.包括大小写字母.数字.其它符号,以上四种至少三种
3.不能有相同长度超2的子串重复

说明:
长度超过2的子串重复,如021Abc9Abc1,其中Abc重复了两次

输入描述:
一组或多组长度超过2的子符串。每组占一行
输出描述:
如果符合要求输出:OK,否则输出NG

示例1
输入
021Abc9000
021Abc9Abc1
021ABC9000
021$bc9000
输出
OK
NG
NG
OK

题解:

思路:本题的思路其实还是比较清晰的,每个密码规则都需要分别做判断,难就难在对正则表达式的理解和使用(python中re模块)

通过一个例子来简单了解下常用的正则表达式

import re

s = 'aaabhh\nacbccd\na\nbbdffabggb'
#a.b释义:a+任意字符+b(任意字符不包括\n)
print(re.findall(r'a.b', s)) #输出['aab', 'acb']
#a*b释义:0个或多个a+b(*是贪婪方式的匹配,即选取尽可能长的匹配字符)
print(re.findall(r'a*b', s)) #输出['aaab', 'b', 'b', 'b', 'ab', 'b']
#a.*b释义&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值