正则表达式匹配 0 和 1 的字符串,不带“011”子串

发布于 2024-08-29 17:36:31 字数 226 浏览 7 评论 0原文

我正在解决一个问题(来自 Hopcroft、Motwani 和 Ullman 的自动机理论、语言和计算机简介),编写一个正则表达式来定义由所有 0< 字符串组成的语言/code>s 和 1s 不包含子字符串 011

答案 (0+1)* - 011 正确吗?如果不是,正确答案应该是什么?

I'm working on a problem (from Introduction to Automata Theory, Languages and Computer by Hopcroft, Motwani and Ullman) to write a regular expression that defines a language consisting of all strings of 0s and 1s not containing the substring 011.

Is the answer (0+1)* - 011 correct ? If not what should be the correct answer for this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

我家小可爱 2024-09-05 17:36:31

自动机图
编辑:更新为包括启动状态和修复,如以下评论所示。

Automata diagram
Edit: Updated to include start states and fixes, as per below comments.

勿忘初心 2024-09-05 17:36:31

如果您正在查找不包含 011 作为子字符串的所有字符串,而不是简单地排除字符串 011

一个经典的正则表达式是:

1*(0+01)*

基本上您可以将一开始有很多你想要的,但是一旦你达到零,它要么是零,要么是零一(因为否则你会得到一个零一一)。

一个现代的、非真正规则的正则表达式是:

^((?!011)[01])*$

但是,如果您想要任何不是 011 的字符串,您可以简单地枚举短字符串并使用通配符其余部分:

λ+0+1+00+01+10+11+(1+00+010)(0+1)*

在现代正则表达式中:

^(?!011)[01]*$

If you are looking for all strings that do not have 011 as a substring rather than simply excluding the string 011:

A classic regex for that would be:

1*(0+01)*

Basically you can have as many ones at the beginning as you want, but as soon as you hit a zero, it's either zeros, or zero-ones that follow (since otherwise you'd get a zero-one-one).

A modern, not-really-regular regex would be:

^((?!011)[01])*$

IF, however, you want any string that is not 011, you can simply enumerate short string and wildcard the rest:

λ+0+1+00+01+10+11+(1+00+010)(0+1)*

And in modern regex:

^(?!011)[01]*$
温暖的光 2024-09-05 17:36:31

最简单的编码(和理解)是:

^(?!.*011)[10]*$

这是禁止子字符串的否定前瞻 (?!.*011),由 1 和 0 组成 [10]* (如果空白不通过,则更改为 [10]+

The simplest to code (and understand) is:

^(?!.*011)[10]*$

This is a negative look ahead (?!.*011) for the prohibited substring, and composed of 1's and 0's [10]* (change to [10]+ if blank is not a pass)

梦年海沫深 2024-09-05 17:36:31

正则表达式如下:

0^* ∣1 + 0^* ∣0^* 01 + 0^*

Here is the regular expression:

0^* ∣1 + 0^∗ ∣0^* 01 + 0^*

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文