hws/hw01.tex
author Christian Urban <christian.urban@kcl.ac.uk>
Fri, 24 Oct 2025 11:26:43 +0100
changeset 1019 43f64633a8a1
parent 967 ce5de01b9632
permissions -rw-r--r--
updated
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
631
f618dd4de24a updated
Christian Urban <urbanc@in.tum.de>
parents: 550
diff changeset
     1
% !TEX program = xelatex
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     2
\documentclass{article}
249
377c59df7297 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 227
diff changeset
     3
\usepackage{../style}
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     4
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     5
\begin{document}
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     6
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     7
\section*{Homework 1}
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
     8
964
da1f8c033b8e updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 962
diff changeset
     9
%%\HEADER
331
a2c18456c6b7 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 294
diff changeset
    10
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    11
\begin{enumerate}
249
377c59df7297 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 227
diff changeset
    12
401
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    13
\item {\bf (Optional)} If you want to run the code presented
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    14
      in the lectures, install the Scala programming language
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    15
      available (for free) from
249
377c59df7297 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 227
diff changeset
    16
743
6acabeecdf75 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 726
diff changeset
    17
      \begin{center}
6acabeecdf75 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 726
diff changeset
    18
        \url{http://www.scala-lang.org}
6acabeecdf75 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 726
diff changeset
    19
      \end{center}
6acabeecdf75 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 726
diff changeset
    20
965
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    21
      and the Ammonite REPL from
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    22
       
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    23
       \begin{center}
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    24
       \url{https://ammonite.io}
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    25
       \end{center}      
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    26
401
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    27
      If you want to follow the code I present during the
962
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    28
      lectures, it might be useful to install VS Code or Codium.
965
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    29
      Please have a look at the handout about Ammonite and
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    30
      if you need a refresher for Scala - I linked on KEATS
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    31
      the Scala handout from PEP.
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    32
      %I will be using Scala Version 3.5, which has the \texttt{scala-cli}
94f5cce73a4f updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 964
diff changeset
    33
      %REPL used in PEP already built in.
962
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    34
      
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    35
      %handout about Scala.
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    36
      %Make sure Ammonite
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    37
      %uses the Scala 3 compiler.
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    38
639
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    39
%\item {\bf (Optional)} Have a look at the crawler programs.
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    40
%      Can you find a usage for them in your daily programming
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    41
%      life? Can you improve them? For example in cases there
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    42
%      are links that appear on different recursion levels, the
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    43
%      crawlers visit such web-pages several times. Can this be
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    44
%      avoided? Also, the crawlers flag as problematic any page
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    45
%      that gives an error, but probably only 404 Not Found
217e66d7aeff updated
Christian Urban <urbanc@in.tum.de>
parents: 631
diff changeset
    46
%      errors should be flagged. Can you change that?)
104
ffde837b1db1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 102
diff changeset
    47
640
281139526cb1 updated
Christian Urban <urbanc@in.tum.de>
parents: 639
diff changeset
    48
\item {\bf (Optional)} Have a look at the catastrophic backtracking
281139526cb1 updated
Christian Urban <urbanc@in.tum.de>
parents: 639
diff changeset
    49
  programs uploaded on KEATS. Convince yourself that they really require
281139526cb1 updated
Christian Urban <urbanc@in.tum.de>
parents: 639
diff changeset
    50
  a lot of computation time. If you have similar examples in your own
281139526cb1 updated
Christian Urban <urbanc@in.tum.de>
parents: 639
diff changeset
    51
  favourite programming language, I am happy to hear about it.
281139526cb1 updated
Christian Urban <urbanc@in.tum.de>
parents: 639
diff changeset
    52
281139526cb1 updated
Christian Urban <urbanc@in.tum.de>
parents: 639
diff changeset
    53
401
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    54
\item Read the handout of the first lecture and the handout
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    55
      about notation. Make sure you understand the concepts of
498
ea47c3b8f35f updated
Christian Urban <urbanc@in.tum.de>
parents: 444
diff changeset
    56
      strings and languages. In the context of the CFL-course,
401
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
    57
      what is meant by the term \emph{language}?
9
Christian Urban <urbanc@in.tum.de>
parents: 0
diff changeset
    58
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    59
      \solution{A language - in this context - is just a set of
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    60
        strings. Some of these sets can actually not be described by
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    61
        regular expressions. Only regular​ languages can. This is
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    62
        something for lecture 3.}
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    63
      
550
71fc4a7a7039 updated
Christian Urban <urbanc@in.tum.de>
parents: 507
diff changeset
    64
\item Give the definition for regular expressions---this is an
498
ea47c3b8f35f updated
Christian Urban <urbanc@in.tum.de>
parents: 444
diff changeset
    65
      inductive datatype. What is the
355
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    66
      meaning of a regular expression? (Hint: The meaning is
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    67
      defined recursively.)
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    68
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    69
      \solution{Here I would also expect the grammar for basic regular
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    70
        expressions and the definition of the recursive L-function. Discuss
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    71
        differences between $r_1 + r_2$ and $r^+$. Discuss differences between
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    72
      ``real-life regexes'' and regexes in this module.}
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    73
355
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    74
\item Assume the concatenation operation of two strings is
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    75
      written as $s_1 @ s_2$. Define the operation of
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    76
      \emph{concatenating} two sets of strings. This operation
394
2f9fe225ecc8 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 355
diff changeset
    77
      is also written as $\_ \,@\, \_$. According to 
2f9fe225ecc8 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 355
diff changeset
    78
      this definition, what is $A \,@\, \{\}$ equal to?
498
ea47c3b8f35f updated
Christian Urban <urbanc@in.tum.de>
parents: 444
diff changeset
    79
      Is in general $A\,@\,B$ equal to $B\,@\,A$?
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
    80
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    81
      \solution{ What is $A @ {[]}$? Are there special cases
962
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    82
        where $A @ B = B @ A$? Obviously when $A = B$ the stament is true.
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    83
        But there are also cases when $A \not= B$, for example $A = \{a\}$
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    84
      and $B = \{aaa\}$.}
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    85
355
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    86
\item Assume a set $A$ contains 4 strings and a set $B$
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    87
      contains 7 strings. None of the strings is the empty
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    88
      string. How many strings are in $A \,@\, B$?
249
377c59df7297 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 227
diff changeset
    89
962
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
    90
      \solution{Everyone will probably answer with 28, but there are corner cases where there are fewer
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    91
        than 28 elements. Can students think of such corner cases?
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    92
      For example $A = \{a, ab, \ldots\}$, $B = \{bc, c,\ldots\}$ }
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    93
267
a1544b804d1e updated homeworks
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 258
diff changeset
    94
\item How is the power of a language defined? (Hint: There are two
a1544b804d1e updated homeworks
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 258
diff changeset
    95
  rules, one for $\_^0$ and one for $\_^{n+1}$.)
109
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 104
diff changeset
    96
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    97
     \solution{Two rules: 0-case and n+1 case.}
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
    98
355
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
    99
\item Let $A = \{[a], [b], [c], [d]\}$. (1) How many strings
438
84608b4b3578 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 416
diff changeset
   100
      are in $A^4$? (2) Consider also the case of $A^4$ where one of
355
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   101
      the strings in $A$ is the empty string, for example $A =
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   102
      \{[a], [b], [c], []\}$.
293
ca349cfe3474 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 267
diff changeset
   103
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   104
      \solution{121 is correct. But make sure you understand why it is 121
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   105
        in cases you do not have a computer at your fingertips.}
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   106
507
fdbc7d0ec04f updated
Christian Urban <urbanc@in.tum.de>
parents: 498
diff changeset
   107
\item (1) How many basic regular expressions are there to match
776
939c10745a3a updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 743
diff changeset
   108
      \textbf{only} the string $abcd$? (2) How many if they cannot include
444
3056a4c071b0 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 438
diff changeset
   109
      $\ONE$ and $\ZERO$? (3) How many if they are also not
3056a4c071b0 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 438
diff changeset
   110
      allowed to contain stars? (4) How many if they are also
401
5d85dc9779b1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 394
diff changeset
   111
      not allowed to contain $\_ + \_$?
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   112
962
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   113
      \solution{1-3 are infinite (tell the idea why and give examples);
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   114
        4 is five - remember regexes are trees (that is the main point of the question.}
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   115
      
355
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   116
\item When are two regular expressions equivalent? Can you
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   117
      think of instances where two regular expressions match
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   118
      the same strings, but it is not so obvious that they do?
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   119
      For example $a + b$ and $b + a$ do not count\ldots they
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   120
      obviously match the same strings, namely $[a]$ and
a259eec25156 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 331
diff changeset
   121
      $[b]$.
403
564f7584eff1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 401
diff changeset
   122
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   123
      \solution{for example $r^* = 1 + r \cdot r^*$ for any regular expression $r$.
967
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   124
        Can students think about why this is the case? - this would need a proof.\bigskip
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   125
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   126
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   127
        Lemma to prove: $A^* = \{[]\} \cup A \times A^*$ for any language $A$.\bigskip
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   128
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   129
        The definition of ${}^*$: $\bigcup n. A^n$\bigskip
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   130
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   131
        We first show $\subseteq$ of the lemma: a string $s \in A^*$, must also be in
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   132
        $\bigcup n. A^n$, which means there is an $n$ such that $s\in A^n$.
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   133
        If $n = 0$ then $s = []$ and $s$ is also in $\{[]\} \cup A \times A^*$.
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   134
        If $n$ is bigger than $0$, then $s\in A^n$, which means by
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   135
        definition of power that $s\in A \times A^{n - 1}$. But then
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   136
        also $s \in A \times A^*$. That is one direction.\bigskip
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   137
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   138
        The other direction: Two cases: (i) $s\in \{[]\}$ then
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   139
        also $s\in A^*$. (ii) $s\in A \times A^*$ means there exists
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   140
        an $n$ such that $s\in A\times A^n$. This in turn means
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   141
        $s\in A^{n + 1}$ (by definition of power). But this also means $s\in A^*$.
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   142
        So $\{[]\} \cup A \times A^*$ is a subset of $A^*$. Done!
ce5de01b9632 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 965
diff changeset
   143
      }
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   144
416
357c395ae838 updated
Christian Urban <urbanc@in.tum.de>
parents: 403
diff changeset
   145
\item What is meant by the notions \emph{evil regular expressions}
726
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   146
  and by \emph{catastrophic backtracking}?
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   147
962
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   148
  \solution{catastrophic backtracking also applies to other regexes,
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   149
    not just $(a^*)^*b$.  Maybe
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   150
    \url{https://www.trevorlasn.com/blog/when-regex-goes-wrong/} is
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   151
    of help - even the CrowdStrike issue had an underlying problem
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   152
    with a regex, though this one was not due to catastrophic
Christian Urban <christian.urban@kcl.ac.uk>
parents: 935
diff changeset
   153
    backtracking.}
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   154
726
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   155
\item Given the regular expression $(a + b)^* \cdot b \cdot (a + b)^*$,
841
564840440523 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 776
diff changeset
   156
  which of the following regular expressions are equivalent
726
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   157
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   158
\begin{center}
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   159
\begin{tabular}{ll}    
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   160
  1) & $(ab + bb)^* \cdot (a + b)^*$\\                     % no
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   161
  2) & $(a + b)^* \cdot (ba + bb + b) \cdot (a + b)^*$\\   % yes
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   162
  3) & $(a + b)^* \cdot (a + b) \cdot (a + b)^*$           % no
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   163
\end{tabular}
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   164
\end{center}
876
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   165
771396fa6cc4 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 841
diff changeset
   166
  \solution{no, yes (why?), no.}
922
e86ea06e3b25 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 916
diff changeset
   167
e86ea06e3b25 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 916
diff changeset
   168
e86ea06e3b25 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 916
diff changeset
   169
\item Given the extended regular expression \texttt{[b-d]a?e+},
e86ea06e3b25 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 916
diff changeset
   170
  what does the equivalent basic regular expression look like?
726
fba480bbc9f7 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 640
diff changeset
   171
  
935
4e221cf587fa updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 927
diff changeset
   172
  \solution{$(b + c + d) \cdot (a + \ONE) \cdot (e \cdot e^*)$}
922
e86ea06e3b25 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 916
diff changeset
   173
  
e86ea06e3b25 updated
Christian Urban <christian.urban@kcl.ac.uk>
parents: 916
diff changeset
   174
  
403
564f7584eff1 updated
Christian Urban <christian dot urban at kcl dot ac dot uk>
parents: 401
diff changeset
   175
\item \POSTSCRIPT  
0
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   176
\end{enumerate}
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   177
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   178
\end{document}
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   179
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   180
%%% Local Variables: 
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   181
%%% mode: latex
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   182
%%% TeX-master: t
3a5e09a2ae54 initial comit
Christian Urban <urbanc@in.tum.de>
parents:
diff changeset
   183
%%% End: