有没有办法否定正则表达式?

2023-12-26

给定一个正则表达式R它描述了一种常规语言(没有花哨的反向引用)。有没有一种算法方法来构造正则表达式R*描述除以下描述的单词之外的所有单词的语言R?应该可以作为维基百科 http://en.wikipedia.org/wiki/Regular_language says:

常规语言在各种操作下是封闭的,也就是说,如果语言K and L是正则的,所以以下运算的结果也是正则的:[...] 补码¬L

例如,给定字母表{a,b,c},语言的逆(abc*)+ is (a|(ac|b|c).*)?


正如 DPenner 已经在评论中指出的那样,正则表达式的逆表达式可以比原始表达式指数大。这使得逆正则表达式不适合实现用于搜索目的的负部分表达式语法。有没有一种算法可以保留O(n*m)运行时特性(其中n是正则表达式的大小,m是正则表达式匹配的输入长度)并允许否定子表达式?


不幸的是,nhahdtdh 在评论中给出的答案已经是我们所能做的最好的了(到目前为止)。给定的正则表达式是否生成所有字符串都是 PSPACE 完整的。由于 NP 中的所有问题都是 PSPACE 完备的,因此普遍性问题的有效解决方案意味着 P=NP。

如果你的问题有一个有效的解决方案,你能解决普遍性问题吗?当然你会的。

  1. 使用高效的算法生成否定的正则表达式;
  2. 确定生成的正则表达式是否生成空集。

请注意,“给定一个正则表达式,它是否生成空集”这个问题相当简单:

  1. 正则表达式{}生成空集。
  2. (r + s)生成空集当且仅当r and s生成空集。
  3. (rs)生成空集 iff 或者r or s生成空集。
  4. 没有其他东西会生成空集。

基本上,很容易判断正则表达式是否生成空集:只需开始评估正则表达式即可。

(请注意,虽然上述过程在输出长度方面是有效的,但如果输出长度比输入长度快超过多项式,则在输入长度方面可能效率不高。但是,如果是这种情况,无论如何,我们都会得到相同的结果,即您的算法并不是真正有效,因为它需要指数级的许多步骤才能从给定的输入生成指数级更长的输出)。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

有没有办法否定正则表达式? 的相关文章

  • 如何使用 C# 查找文本中重复出现的词组? [关闭]

    Closed 这个问题需要多问focused help closed questions 目前不接受答案 我正在统计重复出现的字数字符串生成器 sb 我在互联网上找到了这段代码 据作者称 它与 Word 的字数计数器非常一致 StringB
  • 如何衡量字符串的复杂度?

    我有一些长字符串 1 000 000 个字符 每个字符串仅包含定义字母表中的符号 例如 A 1 2 3 示例字符串 string S1 1111111111 meta complexity 0 string S2 1111222333 me
  • Jquery 表单验证 - 电话号码

    我已经在表单上设置了 jQuery 验证 该验证当前测试电话号码字段不为空并且是一个数字 但我希望它能够处理用户在手机 区号后放置空格的情况 谁能建议我需要做什么才能允许这样做 这是我当前的代码 if phone length 0 name
  • 优化两个三位数乘积的最大回文数?

    我正在研究一个面试问题 我被问到这个问题 我应该编写一个程序 从两个三位数的乘积中找到最大的回文数 这里是question https projecteuler net problem 4 我想出了这种从底部开始的蛮力方法 public c
  • 比 BMH (Boyer–Moore–Horspool) 更快的算法

    您会使用哪种算法来搜索短文本中的短子字符串 简而言之 我的意思是子字符串有 5 10 个字符 字符串有 255 个字符 我正在考虑根据输入数据长度选择算法 哪种算法对于较长的输入更好 Try Turbo BM http www igm un
  • [\b] 退格正则表达式有什么用?

    b 显然匹配退格字符 我无法理解字符串如何包含退格字符 有人能给我一个具体的例子来说明如何使用它吗 非常感谢 虽然所有其他人总体上都是正确的 即 b是单词边界 b does表示字符类中的退格键 b 这确实会匹配退格字符 它只是一个可以出现在
  • 2D形状识别与解析算法

    我正在寻找一种算法 用于从给定的一组 x y 点检测简单形状 如矩形 三角形 正方形和圆形 我还在寻找一种方法 一旦检测到 将路径转换为更干净的形状 我已经查遍了互联网 但没有找到任何 简单 的方法 几乎所有这些对于我的简单实现来说都是高级
  • Scala 正则表达式替换为匿名函数

    在 Ruby 中 我可以通过以下方式替换字符串中的字符 a one1two2three a gsub d e e to i 1 gt one2two3three 从第二行开始评估块的结果将替换模式中匹配的内容 我们可以在 Scala 中做类
  • 测量数组的“无序”程度

    给定一个值数组 我想找到总 分数 其中每个元素的分数是数组中出现在其之前的具有较小值的元素的数量 e g values 4 1 3 2 5 scores 0 0 1 1 4 total score 6 O n 2 算法很简单 但我怀疑可以通
  • 匹配没有周围字符列表的单词列表

    我有这个正则表达式 one common word or another 除非这两个单词相邻 否则它匹配得很好 One one s more word word common word or another word more anothe
  • 寻找簇的中心

    我有以下问题 进行抽象以找出关键问题 我有 10 个点 每个点与其他点有一定距离 我想要 能够找到簇的中心 即与其他点的成对距离最小的点 令 p j p k 表示点 j 和 k 之间的成对距离p i 是簇的中心点 iff p i s t m
  • django 尝试了这些 url 模式

    当我尝试访问我的站点时 它会给出以下信息 使用 mysite urls 中定义的 URLconf Django 按以下顺序尝试了这些 URL 模式 管理员 当前 URL 与其中任何一个都不匹配 如果我访问该网站并附加 admin 它会将我带
  • Javascript拆分正则表达式问题

    你好 我正在尝试我认为在 Javascript 中相当简单的正则表达式 但给我带来了很多麻烦 我希望能够通过 javascript 通过 和 分割日期 var date 02 25 2010 var myregexp2 new RegExp
  • Diamond-Square 算法的平滑问题

    我正在使用菱形方形算法来生成随机地形 它工作得很好 除了我让这些大圆锥形状要么伸出或伸入地形 问题似乎在于 时不时会有一个点被设置得太高或太低 Here is a picture of the problem And it can be b
  • 在 .NET 中使用正则表达式提取 URL

    我从以下 URL 中的示例中获得了灵感csharp 在线 http en csharp online net CSharp Regular Expression Recipes E2 80 94Extracting Groups from
  • 在Python中比较字符串的最快方法

    我正在用 Python 编写一个脚本 该脚本将允许用户输入一个字符串 该字符串将是指示脚本执行特定操作的命令 为了便于讨论 我会说我的命令列表是 lock read write request log 现在 我希望用户能够输入 log 一词
  • 为什么Python中pop()的大O与pop(0)不同[重复]

    这个问题在这里已经有答案了 他们不应该都是O 1 因为从 Python 列表中的任何位置弹出一个元素涉及销毁该列表并在新的内存位置创建一个元素 蟒蛇的list实现使用动态调整大小的 Carray在引擎盖下 删除元素usually要求您移动后
  • 为什么我们需要检测链表中的循环

    我看到很多关于如何检测链表中的循环的问答 但我想了解的是我们为什么要这样做 换句话说 检测链表中的循环的实际用例是什么 在现实生活中 您可能永远不需要检测链表中的循环 但是执行此操作的算法很重要 我在现实生活中多次使用它们 例如 我经常会递
  • RegEx 使用 match() 在 JavaScript 中提取字符串数组

    我正在尝试使用string match 在 javascript 中使用正则表达式来提取字符串数组 这是一个示例字符串 CREATE TABLE listings listing id INTEGER UNIQUE state TEXT t
  • 在哪里可以找到有关双三次插值和 Lanczos 重采样的好读物?

    我想用 C 实现上述两种图像重采样算法 双三次和 Lanczos 我知道现有的实现有几十种 但我仍然想制作自己的实现 我之所以这么做 部分原因是我想了解它们是如何工作的 部分原因是我想为它们提供一些主流实现中没有的功能 例如可配置的多 CP

随机推荐

  • 访问 RFC 调用系统的堆栈内存

    当程序在 SAP ECC 中运行时 系统堆栈 存储所有全局变量 无论在该单个会话中调用什么模块 程序 当它调用支持 RFC 的功能模块 FM 时 会在被调用系统中创建一个新的系统堆栈 并且当被调用 FM 完成时 只能在 ECC 中检索被调用
  • InvalidCharacterError 仅在 IE 中出现

    我们有一个订单表单 它使用 ziplookup 功能 当在字段中输入邮政编码时 城市 县 州和邮政编码也会输入到同一字段中 tr td class formLabel Zip Code td td class formColon nbsp
  • SwiftUI 和 NavigationView 的动画错误可能是什么原因造成的?

    我一直在尝试一些 SwiftUI 布局 我想尝试的事情之一是创建一个简单的圆形进度环 在对代码进行了一段时间的研究之后 我设法让一切都按照我希望的方式工作 至少对于原型来说是这样 当我将此视图嵌入到 SwiftUI NavigationVi
  • 将 python 日期格式 (%Y) 转换为 java (yyyy)

    我有很多时间格式 格式如下 Y m d H M S 有没有快速的方法或库将它们转换为 YYYY MM DD HH MM SS 我当前的方法是使用字符串替换 但也许我会错过一些边缘情况 我可能的格式化程序是 d b Y y H M S p f
  • Node.JS deflate/gzip 响应文本

    我看到了所示的示例here http nodejs org api zlib html zlib examples response writeHead 200 content encoding deflate raw pipe zlib
  • 在可能保存模型时处理 ember-data 中的自定义服务器端错误

    保存模型时是否有正确的方法来处理自定义错误 举个例子 假设我有一个只有两个属性 名称 和 值 的模型 当我这样做时 var myModel this get store createRecord myModel name someName
  • IE9 中 的边框半径错误

    看见那个 div 元素正确渲染边框 边框半径 但任何 a or a div
  • 如何使用 JavaScript 获取滚动条位置?

    我正在尝试使用 JavaScript 检测浏览器滚动条的位置 以确定当前视图在页面中的位置 我的猜测是 我必须检测拇指在轨道上的位置 然后检测拇指的高度占轨道总高度的百分比 我是否过于复杂化了 或者 JavaScript 是否提供了比这更简
  • 当在 contenteditable 按钮中输入空格时,Chrome 会触发 onClick

    我有一个按钮contenteditable true 我可以很好地编辑文本 但无法在 Chrome 中输入空格 当我按下空格键时 Chrome 会在按钮上触发 onClick 事件 然而 Safari 会按照您的预期插入一个空格 使用此代码
  • C++ 的类似 Hibernate 的层

    在 C 中使用 DB 确实是一团糟 当我转向 Java 并能够使用统一的系统将整个层抽象出来 又名 Hibernate 时 这真是令人耳目一新 有几个用于 DB 的 C 抽象层 但它们通常是特定于供应商的 并且只有一个薄层包装了真正的 C
  • 我想单击列表视图中的任意位置(空白区域)

    作为一名新的 Android 程序员 我必须运行我的待办事项应用程序 对于圣诞节购物来说这是可以接受的 但我真的很想让整个列表项行可单击 现在我必须点击文本 物品越短越难击中 我的主要活动扩展了 ListActivity 我将 Resour
  • rspec 测试中 Rails 应用程序的端口号

    我想使用 rspec 结合 Faraday 和 Faraday middleware 来测试 Rails 应用程序的 json 响应 要使用 Faraday 需要应用程序 URL 在测试中我想使用本地主机 端口号 问题是 如何在 rspec
  • 如何在编辑 XML 文件时运行我的项目?

    当我编辑 XML 文件并尝试运行 Android 项目 通过单击工具栏中的 播放 按钮或 command shift F11 时 没有任何反应 我必须切换到我也在编辑的 java 文件才能运行该项目 我怎样才能解决这个问题 您无法运行 xm
  • (PyQt) QTreeView - 想要展开/折叠所有子级和孙级

    我希望能够展开或折叠 QTreeView 中特定分支的所有子级 我正在使用 PyQt4 我知道 QTreeView 有一个绑定到 的展开所有子项功能 但我需要两件事 它需要绑定到不同的组合键 shift space 我还需要能够折叠所有子项
  • React Native - 无法执行 JS 调用:__fbBatchedBridge 未定义

    我一直在关注这个教程https www raywenderlich com 126063 react native tutorial https www raywenderlich com 126063 react native tutor
  • 如何使用Python将主机名添加到known_hosts?

    我正在使用此代码将服务器添加到known hosts subprocess Popen sshpass p password ssh o StrictHostKeyChecking no add key stdout subprocess
  • SELECT DISTINCT 可以与 Perl 的 DBD::CSV 一起使用吗?

    我在网上找到了一个 SELECT example 当我在脚本中尝试它时 我收到此错误消息 Specifying DISTINCT when using aggregate functions isn t reasonable ignored
  • 在Android Gradle任务中获取编译后的.class输出目录

    我正在为我的 Android 项目创建一个 Gradle 任务 它需要知道编译后的路径 class文件 我怎样才能得到这条路径 我找到了建议 here https stackoverflow com a 26667774 3004881 a
  • Nuxtjs 与 scrollmagic 给我“窗口未定义”

    我想将scrollmagic 与nuxtjs 一起使用 我通过npm安装了scrollmagic npm install scrollmagic 在我的 nuxt config js 文件中我添加了 build vendor scrollm
  • 有没有办法否定正则表达式?

    给定一个正则表达式R它描述了一种常规语言 没有花哨的反向引用 有没有一种算法方法来构造正则表达式R 描述除以下描述的单词之外的所有单词的语言R 应该可以作为维基百科 http en wikipedia org wiki Regular la