用正则表达式解代数方程(正则化方程)
yuyutoo 2025-03-19 03:58 4 浏览 0 评论
关注微信:DuoDaaMath每天获得更多数学趣文
作者,Steven Levithan
翻译,radium,哆嗒数学网翻译组成员,数学专业学生
用正则表达式并不擅长解决数学问题。对一个正则表达式系统,字符从0到9,和其他的一样,并没有什么特殊的地方。
在这里我需要提到两个例外Perl和PCRE,这两个例外允许动态代码在匹配过程中的任何一点上运行,这为我们提供了大量额外的契机。Perl是通过代码嵌入正则表达式,PCRE用标注系统去表达外部函数。但正则表达式偏好这些例外,甚至利用他们去拓展自己的能力,让方程式告诉你更多,呈现的更完整。一般的,有关数学的问题像匹配数值范围(matching numeric ranges)(在匹配一些需画大量时间的长文本的任务上很有用)在运行中是一个痛,如果他们有可能的话。
但是在最基本的正则表达式的系统中,这种力量和表现可以引导出一些漂亮的技巧。就像匹配非素长度字符串一样!这时基础的正则表达式就有些出名了。就连一个黑客也会惊讶你是用的是正则表达式来解决的一个简单的线性方程组。我在摆弄 RegexBuddy's 的调试器时无意中蹦出了这个想法。严格的POSIX ERE的实现和其他深邃的味道,不允许反向引用,因此执行本生是简单的,工作也相当普遍。这里有一个样板:
^(.*)\1{A-1}(.*)\2{B-1}$
现在让我们来解关于x和y的方程,像17X+12y=51 ,A和B是常量占位符对应这个例子中的17和12.所以正则表达式成为^(.*)\1{16}(.*)\2{11}$
我们从A,B值中减去1因为我们重复反向引用,而子模式之前已经匹配过一次。如果你运行正则表达式去对付51字符串,当长度为$1
时(反向引用1)将会是3(这就告诉我们x=3),当长度为$2
时(反向引用2)将会是0(意味着y=0)事实上17*3+12*0=51.如果方程没有解,那么正则表达式将无法匹配字符串。如果方程有多种可能的解,那么返回的是x的最大值,因为这个值最早被处理。
快来尝试吧!你可以用正则表达式来解各种各样的你喜欢的形式类似的方程。例如11x+2y+5z=115可以用^(.*)\1{10}(.*)\2{1}(.*)\3{4}$
和115字符的源串来解决(结果是11*10+2*0+5*1=115)。运行^(.*)\1{12}$
去对付247字符的字符串,那么你将会因为反向引用一次得到一个19字符的值,像13*19=247.请记住,随着整数和字符串的长度的增加,变量的数目增加,通过正则表达式软件的回溯的数量也会增加。对于一些图像的门栏这种方法是很慢的甚至无用的。但我不在乎,他依然很酷!
相关推荐
- ETCD 故障恢复(etc常见故障)
-
概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...
- 在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法
-
FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...
- 如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)
-
---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...
- 使用 Fail Ban 日志分析 SSH 攻击行为
-
通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...
- 《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》
-
服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...
- 聊聊Spring AI Alibaba的YuQueDocumentReader
-
序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...
- Mac Docker环境,利用Canal实现MySQL同步ES
-
Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...
- RustDesk:开源远程控制工具的技术架构与全场景部署实战
-
一、开源远程控制领域的革新者1.1行业痛点与解决方案...
- 长安汽车一代CS75Plus2020款安装高德地图7.5
-
不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...
- Zookeeper使用详解之常见操作篇(zookeeper ui)
-
一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...
- zk源码—4.会话的实现原理一(会话层的基本功能是什么)
-
大纲1.创建会话...
- Zookeeper 可观测性最佳实践(zookeeper能够确保)
-
Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...
- 服务器密码错误被锁定怎么解决(服务器密码错几次锁)
-
#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...
- zk基础—4.zk实现分布式功能(分布式zk的使用)
-
大纲1.zk实现数据发布订阅...
- 《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析
-
在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
推荐7个模板代码和其他游戏源码下载的网址
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
-
- ETCD 故障恢复(etc常见故障)
- 在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法
- 如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)
- 使用 Fail Ban 日志分析 SSH 攻击行为
- 《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》
- 聊聊Spring AI Alibaba的YuQueDocumentReader
- Mac Docker环境,利用Canal实现MySQL同步ES
- RustDesk:开源远程控制工具的技术架构与全场景部署实战
- 长安汽车一代CS75Plus2020款安装高德地图7.5
- Zookeeper使用详解之常见操作篇(zookeeper ui)
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)