强大的正则表达式——Easy

news2025/1/21 14:05:10


进入题目界面输入难度1后,让我们输入正则表达式(regex):


目前不清楚题目要求,先去下载附件查看情况:

import re
import random

# pip install libscrc
import libscrc

allowed_chars = "0123456789()|*"
max_len = 1000000
num_tests = 300

difficulty = int(input("Enter difficulty level (1~3): "))
if difficulty not in [1, 2, 3]:
    raise ValueError("Invalid difficulty level")

regex_string = input("Enter your regex: ").strip()

if len(regex_string) > max_len:
    raise ValueError("Regex string too long")

if not all(c in allowed_chars for c in regex_string):
    raise ValueError("Invalid character in regex string")

regex = re.compile(regex_string)

for i in range(num_tests):
    expected_result = (i % 2 == 0)
    while True:
        t = random.randint(0, 2**64)  # random number for testing
        if difficulty == 1:
            test_string = str(t)  # decimal
            if (t % 16 == 0) == expected_result:  # mod 16
                break
        elif difficulty == 2:
            test_string = bin(t)[2:]  # binary
            if (t % 13 == 0) == expected_result:  # mod 13
                break
        elif difficulty == 3:
            test_string = str(t)  # decimal
            if (libscrc.gsm3(test_string.encode()) == 0) == expected_result:  # crc
                break
        else:
            raise ValueError("Invalid difficulty level")
    regex_result = bool(regex.fullmatch(test_string))
    if regex_result == expected_result:
        print("Pass", test_string, regex_result, expected_result)
    else:
        print("Fail", test_string, regex_result, expected_result)
        raise RuntimeError("Failed")

print(open(f"flag{difficulty}").read())

丢给ai分析一下:

1、定义常量:

allowed_chars:允许在正则表达式中使用的字符(0123456789()|*)。

max_len:正则表达式的最大长度(1000000个字符)。

num_tests:测试次数(300次)。


2、获取用户输入:

用户输入难度级别(1、2 或 3)。

用户输入正则表达式字符串。


3、验证正则表达式:

检查正则表达式字符串的长度是否超过最大限制。

检查正则表达式字符串中是否包含不允许的字符。

编译正则表达式。


4、生成测试用例并验证:

循环生成 num_tests 次测试用例。

根据难度级别生成不同的测试字符串:

难度 1:生成一个十进制数,检查其是否能被16整除。

难度 2:生成一个二进制数,检查其是否能被13整除。

难度 3:生成一个十进制数,检查其CRC校验码是否为0。

使用正则表达式匹配测试字符串,并与预期结果进行比较。

如果匹配结果与预期结果一致,打印“Pass”;否则,打印“Fail”并抛出异常。


5、读取并显示标志文件:


这下看懂了,难度1就是写一个正则表达式,要求能够匹配以能被16整除的四位数结尾的十进制数,其中正则表达式允许的字符包括数字(0-9)、括号(())、竖线(|)和星号(*),且正则表达式的长度不能超过最大限制(1000000字符),继续让AI写个python代码来生成一个满足要求的正则表达式:

def generate_divisible_by_16_regex():
    # 生成一个正则表达式,匹配以能被16整除的四位数结尾的十进制数
    string = ""
    for i in range(9999, -1, -1):
        if i % 16 == 0:
            string += f"{i:04d}|"
    
    # 去掉最后一个多余的竖线
    string = string[:-1]
    
    # 构建正则表达式
    regex = f"(0|1|2|3|4|5|6|7|8|9)*({string})"
    
    # 检查正则表达式的长度
    if len(regex) > 1000000:
        raise ValueError("生成的正则表达式超过了1000000字符的最大限制。")
    
    return regex

# 生成正则表达式
divisible_by_16_regex = generate_divisible_by_16_regex()
print(f"生成的正则表达式: {divisible_by_16_regex}")

得到的正则表达式:

(0|1|2|3|4|5|6|7|8|9)*(9984|9968|9952|9936|9920|9904|9888|9872|9856|9840|9824|9808|9792|9776|9760|9744|9728|9712|9696|9680|9664|9648|9632|9616|9600|9584|9568|9552|9536|9520|9504|9488|9472|9456|9440|9424|9408|9392|9376|9360|9344|9328|9312|9296|9280|9264|9248|9232|9216|9200|9184|9168|9152|9136|9120|9104|9088|9072|9056|9040|9024|9008|8992|8976|8960|8944|8928|8912|8896|8880|8864|8848|8832|8816|8800|8784|8768|8752|8736|8720|8704|8688|8672|8656|8640|8624|8608|8592|8576|8560|8544|8528|8512|8496|8480|8464|8448|8432|8416|8400|8384|8368|8352|8336|8320|8304|8288|8272|8256|8240|8224|8208|8192|8176|8160|8144|8128|8112|8096|8080|8064|8048|8032|8016|8000|7984|7968|7952|7936|7920|7904|7888|7872|7856|7840|7824|7808|7792|7776|7760|7744|7728|7712|7696|7680|7664|7648|7632|7616|7600|7584|7568|7552|7536|7520|7504|7488|7472|7456|7440|7424|7408|7392|7376|7360|7344|7328|7312|7296|7280|7264|7248|7232|7216|7200|7184|7168|7152|7136|7120|7104|7088|7072|7056|7040|7024|7008|6992|6976|6960|6944|6928|6912|6896|6880|6864|6848|6832|6816|6800|6784|6768|6752|6736|6720|6704|6688|6672|6656|6640|6624|6608|6592|6576|6560|6544|6528|6512|6496|6480|6464|6448|6432|6416|6400|6384|6368|6352|6336|6320|6304|6288|6272|6256|6240|6224|6208|6192|6176|6160|6144|6128|6112|6096|6080|6064|6048|6032|6016|6000|5984|5968|5952|5936|5920|5904|5888|5872|5856|5840|5824|5808|5792|5776|5760|5744|5728|5712|5696|5680|5664|5648|5632|5616|5600|5584|5568|5552|5536|5520|5504|5488|5472|5456|5440|5424|5408|5392|5376|5360|5344|5328|5312|5296|5280|5264|5248|5232|5216|5200|5184|5168|5152|5136|5120|5104|5088|5072|5056|5040|5024|5008|4992|4976|4960|4944|4928|4912|4896|4880|4864|4848|4832|4816|4800|4784|4768|4752|4736|4720|4704|4688|4672|4656|4640|4624|4608|4592|4576|4560|4544|4528|4512|4496|4480|4464|4448|4432|4416|4400|4384|4368|4352|4336|4320|4304|4288|4272|4256|4240|4224|4208|4192|4176|4160|4144|4128|4112|4096|4080|4064|4048|4032|4016|4000|3984|3968|3952|3936|3920|3904|3888|3872|3856|3840|3824|3808|3792|3776|3760|3744|3728|3712|3696|3680|3664|3648|3632|3616|3600|3584|3568|3552|3536|3520|3504|3488|3472|3456|3440|3424|3408|3392|3376|3360|3344|3328|3312|3296|3280|3264|3248|3232|3216|3200|3184|3168|3152|3136|3120|3104|3088|3072|3056|3040|3024|3008|2992|2976|2960|2944|2928|2912|2896|2880|2864|2848|2832|2816|2800|2784|2768|2752|2736|2720|2704|2688|2672|2656|2640|2624|2608|2592|2576|2560|2544|2528|2512|2496|2480|2464|2448|2432|2416|2400|2384|2368|2352|2336|2320|2304|2288|2272|2256|2240|2224|2208|2192|2176|2160|2144|2128|2112|2096|2080|2064|2048|2032|2016|2000|1984|1968|1952|1936|1920|1904|1888|1872|1856|1840|1824|1808|1792|1776|1760|1744|1728|1712|1696|1680|1664|1648|1632|1616|1600|1584|1568|1552|1536|1520|1504|1488|1472|1456|1440|1424|1408|1392|1376|1360|1344|1328|1312|1296|1280|1264|1248|1232|1216|1200|1184|1168|1152|1136|1120|1104|1088|1072|1056|1040|1024|1008|0992|0976|0960|0944|0928|0912|0896|0880|0864|0848|0832|0816|0800|0784|0768|0752|0736|0720|0704|0688|0672|0656|0640|0624|0608|0592|0576|0560|0544|0528|0512|0496|0480|0464|0448|0432|0416|0400|0384|0368|0352|0336|0320|0304|0288|0272|0256|0240|0224|0208|0192|0176|0160|0144|0128|0112|0096|0080|0064|0048|0032|0016|0000)


输入难度1再输入得到的正则表达式:

成功得到flag

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

字节青训-小C的外卖超时判断、小C的排列询问

目录 一、小C的外卖超时判断 问题描述 测试样例 解题思路: 问题理解 数据结构选择 算法步骤 最终代码: 运行结果: 二、小C的排列询问 问题描述 测试样例 最终代码: 运行结果: ​编辑 一、小C的外卖超时判断…

游戏引擎学习第13天

视频参考:https://www.bilibili.com/video/BV1QQUaYMEEz/ 改代码的地方尽量一张图说清楚吧,懒得浪费时间 game.h #pragma once #include <cmath> #include <cstdint> #include <malloc.h>#define internal static // 用于定义内翻译单元内部函数 #…

C++11(五)----lambda表达式

文章目录 lambda表达式 lambda表达式 lambda表达式可以看作一个匿名函数 语法 [capture-list] (parameters) mutable -> return-type { statement } auto func1 [](int a, int b) mutable -> int {return a b; }; *capture-list&#xff1a;捕捉列表。编译器根据[]来 判…

CSS基础知识05(弹性盒子、布局详解,动画,3D转换,calc)

目录 0、弹性盒子、布局 0.1.弹性盒子的基本概念 0.2.弹性盒子的主轴和交叉轴 0.3.弹性盒子的属性 flex-direction row row-reverse column column-reverse flex-wrap nowrap wrap wrap-reverse flex-dirction和flex-wrap的组合简写模式 justify-content flex-s…

【Qt聊天室】客户端实现总结

目录 1. 项目概述 2. 功能实现 2.1 主窗口设计 2.2 功能性窗口 2.3 主界面功能实现 2.4 聊天界面功能实现 2.5 个人信息功能开发 2.6 用户信息界面设置功能 2.7 单聊与群聊 2.8 登录窗口 2.9 消息功能 3. 核心设计逻辑 3.1 核心类 3.2 前后端交互与DataCenter 4…

RK3568平台开发系列讲解(高级字符设备篇)IO 模型引入实验

🚀返回专栏总目录 文章目录 一、IO 的概念二、IO 执行过程三、IO 模型的分类阻塞 IO非阻塞 IOIO 多路复用信号驱动异步 IO沉淀、分享、成长,让自己和他人都能有所收获!😄 一、IO 的概念 IO 是英文 Input 和 Output 的首字母, 代表了输入和输出, 当然这样的描述有一点点…

简单实现QT对象的[json]序列化与反序列化

简单实现QT对象的[json]序列化与反序列化 简介应用场景qt元对象系统思路实现使用方式题外话 简介 众所周知json作为一种轻量级的数据交换格式&#xff0c;在开发中被广泛应用。因此如何方便的将对象数据转为json格式和从json格式中加载数据到对象中就变得尤为重要。 在python类…

【qt】控件2

1.frameGeometry和Geometry区别 frameGeometry是开始从红圈开始算&#xff0c;Geometry从黑圈算 程序证明&#xff1a;使用一个按键&#xff0c;当按键按下,qdebug打印各自左上角的坐标&#xff08;相当于屏幕左上角&#xff09;&#xff0c;以及窗口大小 Widget::Widget(QWid…

LeetCode654.最大二叉树

LeetCode刷题记录 文章目录 &#x1f4dc;题目描述&#x1f4a1;解题思路⌨C代码 &#x1f4dc;题目描述 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点&#xff0c;其值为 nums 中的最大值。 递归地在最大值 左边 的 子…

华为欧拉系统使用U盘制作引导安装华为欧拉操作系统

今天记录一下通过U盘来安装华为欧拉操作系统 华为欧拉操作系统是国产的一个类似于Centos的Linus系统 具体实现操作步骤&#xff1a; 先在官网下载欧拉系统镜像点击跳转到下载 准备好一个大于16g的U盘 &#xff0c;用于制作U盘启动 下载一个引导程序制作工具&#xff0c;我使用…

软考教材重点内容 信息安全工程师 第 3 章 密码学基本理论

&#xff08;本章相对老版本极大的简化&#xff0c;所有与算法相关的计算全部删除&#xff0c;因此考试需要了解各个常 用算法的基本参数以及考试中可能存在的古典密码算法的计算&#xff0c;典型的例子是 2021 和 2022 年分别考了 DES 算法中的 S 盒计算&#xff0c;RSA 中的已…

如何让手机ip变成动态

在数字化浪潮中&#xff0c;手机已成为我们日常生活中不可或缺的一部分。无论是浏览网页、使用社交媒体还是进行在线购物&#xff0c;手机都扮演着举足轻重的角色。然而&#xff0c;在享受网络带来的便利时&#xff0c;我们也需要关注网络安全和隐私保护。静态IP地址可能让手机…

64位程序调用32位dll解决方案

最近在做64位代码移植&#xff0c;发现很多老代码使用到了第三方的32位dll;而且这些第三方32位dll库已经年代久远&#xff0c;原开发商已不再了&#xff1b;所以急切的需要在64位主程序 中使用老的32位dll;查询很多解决方案 发现目前只有使用com 进程外组件的方法可以解决此问题…

无人机挂载超细干粉灭火装置技术详解

无人机挂载超细干粉灭火装置技术是一种创新的灭火方式&#xff0c;结合了无人机的远程操控能力和超细干粉灭火剂的高效灭火性能。以下是对该技术的详细解析&#xff1a; 一、技术背景与原理 背景&#xff1a;高层建筑灭火救援困难一直是公认的世界性难题。无人机技术的发展为…

信号-3-信号处理

main 信号捕捉的操作 sigaction struct sigaction OS不允许信号处理方法进行嵌套&#xff1a;某一个信号正在被处理时&#xff0c;OS会自动block改信号&#xff0c;之后会自动恢复 同理&#xff0c;sigaction.sa_mask 为捕捉指定信号后临时屏蔽的表 pending什么时候清零&…

Linux的指令(三)

1.grep指令 功能&#xff1a; 在文件中搜索字符串&#xff0c;将找到的行打印出来 -i&#xff1a;忽略大小写的不同&#xff0c;所以大小写视为一样 -n&#xff1a;顺便输出行号 -v:反向选择&#xff0c;就是显示出没有你输入要搜索内容的内容 代码示例&#xff1a; roo…

onvif协议相关:4.1.7 Digest方式云台控制停止

背景 关于onvif的其实很早之前我已经在专栏中写了不少了, 使用onvif协议操作设备 但最近有陆陆续续的粉丝问我, 希望我在写一些关于 onvif的设备自动发现、预置位跳转、云台操作的博客。 满足粉丝的需求,安排。 今天我们来实现 设备云台的控制(启动) 实现 1.在ONVIF Devi…

【机器学习】数学知识:标准差,方差,协方差,平均数,中位数,众数

标准差、方差和协方差是统计学中重要的概念&#xff0c;用于描述数据的分散程度和变量之间的关系。以下是它们的定义和公式&#xff1a; 1. 标准差 (Standard Deviation) 标准差是方差的平方根&#xff0c;表示数据的分散程度&#xff0c;以与数据相同的单位表示。 公式&…

数据结构习题——有效的括号(栈),栈与队列和互相实现,循环队列的实现

文章目录 前言1、有效的括号题目思路代码 2、用队列实现栈题目思路代码 3、用栈实现对列题目思路代码 4、设计循环队列4.1循环队列的概念和了解题目思路代码 总结 前言 继上篇博客学习了栈与队列之后&#xff0c;今天我们来尝试着使用他们来写一些题目&#xff0c;话不多说&…

Java连接MySQL(测试build path功能)

Java连接MySQL&#xff08;测试build path功能&#xff09; 实验说明下载MySQL的驱动jar包连接测试的Java代码 实验说明 要测试该情况&#xff0c;需要先安装好MySQL的环境&#xff0c;其实也可以通过测试最后提示的输出来判断build path是否成功&#xff0c;因为如果不成功会直…