정규식

Regular Expression 다음과 같이 재귀 적으로 정의 할 수 있습니다-

  • ε 정규식은 빈 문자열을 포함하는 언어를 나타냅니다. (L (ε) = {ε})

  • φ 빈 언어를 나타내는 정규식입니다. (L (φ) = { })

  • x 정규식입니다. L = {x}

  • 만약 X 언어를 나타내는 정규 표현식입니다. L(X)Y 언어를 나타내는 정규 표현식입니다. L(Y), 다음

    • X + Y 언어에 해당하는 정규식입니다. L(X) ∪ L(Y) 어디 L(X+Y) = L(X) ∪ L(Y).

    • X . Y 언어에 해당하는 정규식입니다. L(X) . L(Y) 어디 L(X.Y) = L(X) . L(Y)

    • R* 언어에 해당하는 정규식입니다. L(R*)어디 L(R*) = (L(R))*

  • 규칙 중 하나를 1에서 5까지 여러 번 적용하면 정규식입니다.

일부 RE 예

정규식 일반 세트
(0 + 10 *) L = {0, 1, 10, 100, 1000, 10000,…}
(0 * 10 *) L = {1, 01, 10, 010, 0010,…}
(0 + ε) (1 + ε) L = {ε, 0, 1, 01}
(a + b) * 널 문자열을 포함하여 모든 길이의 a 및 b 문자열 세트. 그래서 L = {ε, a, b, aa, ab, bb, ba, aaa …….}
(a + b) * abb abb 문자열로 끝나는 a와 b의 문자열 집합입니다. 그래서 L = {abb, aabb, babb, aaabb, ababb, ………… ..}
(11) * 빈 문자열을 포함하여 짝수의 1로 구성된 집합이므로 L = {ε, 11, 1111, 111111, ……….}
(aa) * (bb) * b a의 짝수와 b의 홀수로 구성된 문자열 세트이므로 L = {b, aab, aabbb, aabbbbb, aaaab, aaaabbb, ………… ..}
(aa + ab + ba + bb) * 짝수 길이의 a와 b의 문자열은 null을 포함하여 문자열 aa, ab, ba 및 bb의 모든 조합을 연결하여 얻을 수 있으므로 L = {aa, ab, ba, bb, aaab, aaba, ………… .. }