hws/hw04.tex
changeset 102 1ab41c59e3d3
parent 93 4794759139ea
child 146 9da175d5eb63
equal deleted inserted replaced
101:4758a6155878 102:1ab41c59e3d3
       
     1 \documentclass{article}
       
     2 \usepackage{charter}
       
     3 \usepackage{hyperref}
       
     4 \usepackage{amssymb}
       
     5 \usepackage{amsmath}
       
     6 
       
     7 \newcommand{\dn}{\stackrel{\mbox{\scriptsize def}}{=}}% for definitions
       
     8 
       
     9 \begin{document}
       
    10 
       
    11 \section*{Homework 4}
       
    12 
       
    13 \begin{enumerate}
       
    14 \item Why is every finite set of strings a regular language?
       
    15 
       
    16 \item What is the language recognised by the regular expressions $(\varnothing^*)^*$.
       
    17 
       
    18 \item If a regular expression $r$ does not contain any occurrence of $\varnothing$ 
       
    19 is it possible for $L(r)$ to be empty?
       
    20 
       
    21 \item Assume that $s^{-1}$ stands for the operation of reversing a
       
    22 string $s$. Given the following \emph{reversing} function on regular 
       
    23 expressions
       
    24 
       
    25 \begin{center}
       
    26 \begin{tabular}{r@{\hspace{1mm}}c@{\hspace{1mm}}l}
       
    27 $rev(\varnothing)$   & $\dn$ & $\varnothing$\\
       
    28 $rev(\epsilon)$         & $\dn$ & $\epsilon$\\
       
    29 $rev(c)$                      & $\dn$ & $c$\\
       
    30 $rev(r_1 + r_2)$        & $\dn$ & $rev(r_1) + rev(r_2)$\\
       
    31 $rev(r_1 \cdot r_2)$  & $\dn$ & $rev(r_2) \cdot rev(r_1)$\\
       
    32 $rev(r^*)$                   & $\dn$ & $rev(r)^*$\\
       
    33 \end{tabular}
       
    34 \end{center}
       
    35 
       
    36 
       
    37 and the set
       
    38 
       
    39 \begin{center}
       
    40 $Rev\,A \dn \{s^{-1} \;|\; s \in A\}$
       
    41 \end{center}
       
    42 
       
    43 prove whether
       
    44 
       
    45 \begin{center}
       
    46 $L(rev(r)) = Rev (L(r))$
       
    47 \end{center}
       
    48 
       
    49 holds.
       
    50 
       
    51 \item Give a regular expression over the alphabet $\{a,b\}$ recognising all strings 
       
    52 that do not contain any substring $bb$ and end in $a$.
       
    53 
       
    54 \item Assume the delimiters for comments are \texttt{$\slash$*} and \texttt{*$\slash$}.
       
    55 Give a regular expression that can recognise comments
       
    56 of the form 
       
    57 
       
    58 \begin{center}
       
    59 \texttt{$\slash$*~\ldots{}~*$\slash$} 
       
    60 \end{center}
       
    61 
       
    62 where the three dots stand for arbitrary characters, but not comment delimiters.
       
    63 (Hint: You can assume you are already given a regular expression written \texttt{ALL},
       
    64 that can recognise any character, and a regular expression \texttt{NOT} that recognises
       
    65 the complement of a regular expression.)
       
    66 
       
    67 \item Given the alphabet $\{a,b\}$. Draw the automaton that has two states, say  $q_0$ and $q_1$.
       
    68 The starting state is $q_0$ and the final state is $q_1$. The transition
       
    69 function is given by
       
    70 
       
    71 \begin{center}
       
    72 \begin{tabular}{l}
       
    73 $(q_0, a) \rightarrow q_0$\\
       
    74 $(q_0, b) \rightarrow q_1$\\
       
    75 $(q_1, b) \rightarrow q_1$
       
    76 \end{tabular}
       
    77 \end{center}
       
    78 
       
    79 What is the languages recognised by this automaton?
       
    80 
       
    81 \item Give a deterministic finite automaton that can recognise 
       
    82 the language $L(a^*\cdot b\cdot b^*)$. 
       
    83 
       
    84 
       
    85 \item (Optional) The tokenizer in \texttt{regexp3.scala} takes as
       
    86 argument a string and a list of rules. The result is a list of tokens. Improve this tokenizer so 
       
    87 that it filters out all comments and whitespace from the result.
       
    88 
       
    89 \item (Optional) Modify the tokenizer in \texttt{regexp2.scala} so that it
       
    90 implements the \texttt{findAll} function. This function takes a regular
       
    91 expressions and a string, and returns all substrings in this string that 
       
    92 match the regular expression.
       
    93 \end{enumerate}
       
    94 
       
    95 % explain what is a context-free grammar and the language it generates 
       
    96 %
       
    97 %
       
    98 % Define the language L(M) accepted by a deterministic finite automaton M.
       
    99 %
       
   100 %
       
   101 % does (a + b)*b+ and (a*b+) + (b*b+) define the same language
       
   102 
       
   103 
       
   104 \end{document}
       
   105 
       
   106 %%% Local Variables: 
       
   107 %%% mode: latex
       
   108 %%% TeX-master: t
       
   109 %%% End: