--- a/handouts/ho03.tex Thu Nov 21 14:41:53 2019 +0000
+++ b/handouts/ho03.tex Fri Nov 22 13:03:13 2019 +0000
@@ -1063,7 +1063,7 @@
\noindent
To conclude this section, how conveniently we can
implement the subset construction with our versions of NFAs and
-DFAs? Very conveninetly. The code is just:
+DFAs? Very conveniently. The code is just:
{\small\begin{lstlisting}[language=Scala]
def subset[A, C](nfa: NFA[A, C]) : DFA[Set[A], C] = {
@@ -1273,7 +1273,7 @@
$\epsilon$NFA, then translate it into a NFA by removing all
$\epsilon$-transitions, and then via the subset construction obtain a
DFA. In all steps we made sure the language, or which strings can be
-recognised, stays the same. Of couse we should have proved this in
+recognised, stays the same. Of cause we should have proved this in
each step, but let us cut corners here. After the last section, we
can even minimise the DFA (maybe not in code). But again we made sure
the same language is recognised. You might be wondering: Can we go
@@ -1345,9 +1345,9 @@
Q_2 & = & Q_0\,a\,a + Q_2\,a
\end{eqnarray}
-\noindent where in Equation (4) we have two occurrences
+\noindent where in Equation (6) we have two occurrences
of $Q_0$. Like the laws about $+$ and $\cdot$, we can simplify
-Equation (4) to obtain the following two equations:
+Equation (6) to obtain the following two equations:
\begin{eqnarray}
Q_0 & = & \ONE + Q_0\,(b + a\,b) + Q_2\,b\\
@@ -1468,7 +1468,7 @@
automaton that recognises all its strings.
\end{quote}
-\noindent Note that this is not a stement for a particular language
+\noindent Note that this is not a statement for a particular language
(that is a particular set of strings), but about a large class of
languages, namely the regular ones.