0

0

好东西

霞舞

霞舞

发布时间:2024-09-22 16:24:09

|

556人浏览过

|

来源于dev.to

转载

好东西

每周挑战 287

穆罕默德·s·安瓦尔 (mohammad s. anwar) 每周都会发出“每周挑战”,让我们所有人都有机会为每周两次的任务提出解决方案。我的解决方案首先用python编写,然后转换为perl。这对我们所有人来说都是练习编码的好方法。

挑战,我的解决方案

任务 1:强密码

任务

给你一个字符串,$str。

编写一个程序,返回使给定字符串成为非常强的密码所需的最少步骤。如果它已经很强,则返回 0。

标准:

  • 必须至少有 6 个字符。
  • 必须包含至少一个小写字母、至少一个大写字母和至少一个数字。
  • 连续不得包含 3 个重复字符。

以下可视为一个步骤:

  • 插入一个字符
  • 删除一个字符
  • 将一个字符替换为另一个字符

我的解决方案

这绝对是本周两项任务中较难的一项。我的白板为此得到了很好的锻炼!

似乎不存在删除字符比替换字符更有利的用例,因此我可以将其从等式中删除。

似乎有三种类型的更改,我将其定义如下。

  1. 如果有三个或更多连续字符,我们需要将第三个字符替换为不同的字符。这存储为 cons_count。如果有六个或更多连续字符,我们需要替换第三个和第六个字符。九个或更多需要三个更改,依此类推。
  2. 如果密码太短,我会将缺少的字符数存储为变量 char_count。
  3. 变量 type_count 计算缺失的类型。如果缺少小写字母,我添加 1,如果缺少大写字母,我添加 1,如果缺少数字,我添加 1。

但是,type_count 列表中的更改可以被其他两个更改之一覆盖。例如,如果 abbbbb 是提供的密码,我们可以将其更改为 abb1bb,这涵盖了类型更改和连续字符更改。同样,abcde 到 abcde1 将涵盖类型更改和短密码更改。

Cleanup.pictures
Cleanup.pictures

智能移除图片中的物体、文本、污迹、人物或任何不想要的东西

下载

因此我返回 cons_count + char_count 和 type_count 的最大值。

def strong_password(password: str) -> int:
    cons_count = 0
    for c in re.findall(r'((.)\2{2,})', password):
        # for every 3 consecutive characters, we need to replace one
        cons_count += len(c[0]) // 3

    char_count = max(0, 6 - len(password))

    type_count = 0
    if not re.search(r'[a-z]', password):
        type_count += 1
    if not re.search(r'[a-z]', password):
        type_count += 1
    if not re.search(r'[0-9]', password):
        type_count += 1

    return max(cons_count + char_count, type_count)

我相信这是正确的逻辑。可能有一些我没有考虑到的边缘情况。

示例

$ ./ch-1.py a
5

$ ./ch-1.py ab2
3

$ ./ch-1.py paasw0rd
0

$ ./ch-1.py paaasw0rd
1

$ ./ch-1.py aaaaa
2

任务 2:有效号码

任务

给你一个字符串,$str。

编写一个脚本来查找它是否是有效数字。

有效号码的条件:

  • 一个整数,后跟一个可选的指数。
  • 一个十进制数,后跟一个可选的指数。
  • 整数是用可选的符号“-”或“+”后跟数字来定义的。

十进制数:十进制数由可选符号“-”或“+”定义,后跟以下定义之一:

  • 数字后跟一个点“.”。
  • 数字后跟一个点“.”后面跟着数字。
  • 一个点“.”后面跟着数字。

指数:指数是用指数符号“e”或“e”后跟一个整数来定义的。

我的解决方案

这相对简单。这是我的解决方案。

def valid_number(s: str) -> bool:
    return bool(re.search(r'^[+-]?([0-9]+\.?[0-9]*|\.[0-9]+)([ee][+-]?[0-9]+)?$', s))

我使用正则表达式,根据是否匹配返回 true 或 false。以下是正则表达式的细分:

  1. ^ 和 $ 确保它匹配整个字符串。
  2. [+-]?允许可选的签名前缀。
  3. ([0-9]+.?[0-9]*|.[0-9]+) 将匹配一个数字(可选后跟一个点)和更多数字(| 的左侧,或一个点后跟)多一位数字(右侧)。
  4. 最后,([ee][+-]?[0-9]+)?将选择性地允许字母 e、可选的签名字符以及一个或多个数字。

我使用 [0-9] 而不是 d,因为在 perl 中,后者将匹配英语以外的语言中的数字。这是我很久以前添加书签的博客文章中讨论的。 https://blogs.perl.org/users/ben_bullock/2017/05/d-does-not-validate-numbers.html

示例

$ ./ch-2.py 1.
True

$ ./ch-2.py 1.
true

$ ./ch-2.py a
false

$ ./ch-2.py .
false

$ ./ch-2.py 1.2e4.2
false

$ ./ch-2.py -1.
true

$ ./ch-2.py +1E-8
true

$ ./ch-2.py .44
true

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

正则表达式不包含
正则表达式不包含

正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

258

2023.07.05

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

766

2023.07.05

java正则表达式匹配字符串
java正则表达式匹配字符串

在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

219

2023.08.11

正则表达式空格
正则表达式空格

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

356

2023.08.31

Python爬虫获取数据的方法
Python爬虫获取数据的方法

Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

293

2023.11.13

正则表达式空格如何表示
正则表达式空格如何表示

正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

244

2023.11.17

正则表达式中如何匹配数字
正则表达式中如何匹配数字

正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

547

2023.12.06

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号