3.3.3 Lexical Analyzer Generator Step 3:
Conversion to a Minimal DFA
Minimizing a DFA consists of merging states which perform the same action.
They can be found by repeated partitoning. We will show this for an NFA in table form.
Final states 2 and 4 are shown in boldface:
data:image/s3,"s3://crabby-images/1de45/1de45b84d1b6247fd813c944fac0732bee630842" alt=""
The first step is to partition the table into final and non-final states:
data:image/s3,"s3://crabby-images/2a3f0/2a3f05b83a387ace88d9ac71aa5154048f5759f2" alt=""
The partioning continues by partitioning out states that lead to the same partition for
the same input. Here, states 1, 3, and 5 lead to the last partitioned state upon reading a
"$", while state 0 does not, so we put state 0 into a new partition:
data:image/s3,"s3://crabby-images/185ec/185ec7b8ffe12706313206925cc4bf7f6d2c1ccc" alt=""
All states in the second partition go to the same partition upon reading a letter or
digit, and they all go to the third partition upon reading a "$". Thus, we are
done, and relabeling the state table yields:
data:image/s3,"s3://crabby-images/92912/92912e775599a9ea90b813c6dcd13be8841fe4ca" alt=""
This concludes the minimization step (see Exercise 8 )and
the procedure for conversion of a regular expression to a minimal finite automation, that
is, we have described a lexical analyzer generator.
data:image/s3,"s3://crabby-images/95292/95292e2604b1b773f8ccdaa36926179e064412eb" alt=""
Send questions and comments to: Karen Lemone
|