Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

In Exercises 16–22 find the language recognized by the given deterministic finite-state automaton

Short Answer

Expert verified

The result is \({\bf{L(M) = \{ 0\} *}} \cup {\bf{\{ 0\} *\{ 1\} }} \cup {\bf{\{ 0\} *\{ 100,1110\} \{ 1\} *}}\)

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

According to the figure.

Here the given figure contains five states \({{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{\bf{,}}{{\bf{s}}_{\bf{4}}}{\bf{,}}{{\bf{s}}_{\bf{5}}}\)

If there is an arrow from \({{\bf{s}}_{\bf{i}}}\)to\({{\bf{s}}_{\bf{j}}}\) with label x, then we write it down in a row \({{\bf{s}}_{\bf{j}}}\) and in the row \({{\bf{s}}_{\bf{i}}}\) and in column x of the following table.

State

0

1

\({{\bf{s}}_{\bf{o}}}\)

\({{\bf{s}}_{\bf{o}}}\)

\({{\bf{s}}_{\bf{1}}}\)

\({{\bf{s}}_{\bf{1}}}\)

\({{\bf{s}}_{\bf{3}}}\)

\({{\bf{s}}_{\bf{2}}}\)

\({{\bf{s}}_{\bf{2}}}\)

\({{\bf{s}}_{\bf{4}}}\)

\({{\bf{s}}_{\bf{3}}}\)

\({{\bf{s}}_{\bf{3}}}\)

\({{\bf{s}}_{\bf{5}}}\)

\({{\bf{s}}_{\bf{4}}}\)

\({{\bf{s}}_{\bf{4}}}\)

\({{\bf{s}}_{\bf{4}}}\)

\({{\bf{s}}_{\bf{4}}}\)

\({{\bf{s}}_{\bf{5}}}\)

\({{\bf{s}}_{\bf{4}}}\)

\({{\bf{s}}_{\bf{5}}}\)

\({{\bf{s}}_{\bf{o}}}\)is marked as the start state.

Since \({{\bf{s}}_{\bf{o}}}\),\({{\bf{s}}_{\bf{1}}}\)and\({{\bf{s}}_{\bf{5}}}\) are encircled twice, a string will be recognized by the deterministic finite state automaton if we end at the state \({{\bf{s}}_{\bf{o}}}\) or a state \({{\bf{s}}_{\bf{1}}}\) or state \({{\bf{s}}_{\bf{5}}}\).

02

Find the final result.

I can end up at a state \({{\bf{s}}_{\bf{0}}}\) if the string is empty or if the string contains only 0’s. Since \({{\bf{s}}_{\bf{0}}}\) is final, the string containing only 0’s and the empty string are all contained in the recognized language.

\({\bf{\{ }}0{\bf{\} *}} \subseteq {\bf{L(M)}}\)

I can only end up at state \({{\bf{s}}_{\bf{1}}}\) if the string contains only a 1 or any amount of zeros followed by a 1. Since \({{\bf{s}}_{\bf{1}}}\) is final, these strings are then contained in the recognized language.

\({\bf{\{ 0\} *\{ 1\} }} \in {\bf{L(M)}}\)

I can end at the state \({{\bf{s}}_{\bf{5}}}\) if the string contains any number of zeros, followed by a 1, followed by a 0, and again followed by a 0. I can also remain at \({{\bf{s}}_{\bf{5}}}\) of the next bits are all 1. Since \({{\bf{s}}_{\bf{5}}}\) is final, these strings are then contained in the recognized language.

\({\bf{\{ 0\} *\{ 1\} \{ 0\} \{ 0\} \{ 1\} * = \{ 0\} \{ 100\} \{ 1\} *}} \in {\bf{L(M)}}\)

I can also end up in a state \({{\bf{s}}_{\bf{5}}}\), if the string contains any number of zeros, followed by a 1, followed by a 1, again followed by a 1, and then followed by 0. I also remain at\({{\bf{s}}_{\bf{5}}}\), if the next bit is all 1. Since \({{\bf{s}}_{\bf{5}}}\) is final, these strings are then contained in the recognized language.

\({\bf{\{ 0\} \{ 1\} \{ 1\} \{ 1\} \{ 0\} \{ 1\} * = \{ 0\} \{ 11110\} \{ 1\} *}} \in {\bf{L(M)}}\)

Therefore, the language generated by the machine is:

\(\begin{array}{c}{\bf{L(M) = \{ 0\} *}} \cup {\bf{\{ 0\} *\{ 1\} }} \cup {\bf{\{ 0\} \{ 100\} \{ 1\} *}} \cup {\bf{\{ 0\} \{ 11110\} \{ 1\} *}}\\{\bf{L(M) = \{ 0\} *}} \cup {\bf{\{ 0\} *\{ 1\} }} \cup {\bf{\{ 0\} *\{ 100,1110\} \{ 1\} *}}\end{array}\)

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Study anywhere. Anytime. Across all devices.

Sign-up for free