data:image/s3,"s3://crabby-images/af201/af201788a5dfc89d25b417f53d2ca9db085166d6" alt=""
Regular Expressions
data:image/s3,"s3://crabby-images/af201/af201788a5dfc89d25b417f53d2ca9db085166d6" alt=""
- The regular expressions over alphabet specifies a language according to
the following rules.
is a regular expression that denotes {
},
that is, the set containing the empty string.
- If a is a symbol in alphabet, then a is a regular expression that denotes
{a}, that is, the set containing the string a.
- Suppose r and s are regular expression denoting the languages L(r) and L(s).
Then
- (r)|(s) is a regular expression denoting L(r) U L(s).
- (r)(s) is a regular expression denoting L(r) L(s).
- (r)* is a regular expression denoting (L(r))*.
- (r) is a regular expression denoting L(r), that is, extra pairs of
parentheses may be used around regular expressions.
Unnecessary parenthesis can be avoided in regular expressions using the
following conventions:
- The unary operator * (kleene closure) has the highest precedence and is
left associative.
- Concatenation has a second highest precedence and is left associative.
- Union has lowest precedence and is left associative.
data:image/s3,"s3://crabby-images/af201/af201788a5dfc89d25b417f53d2ca9db085166d6" alt=""
data:image/s3,"s3://crabby-images/a0e43/a0e43ad46a6b96c790db43a9496e6320ad397048" alt=""