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

Construct nondeterministic finite-state automata that recognize each of these sets.

  1. \(\left\{ {{\bf{\lambda ,0}}} \right\}\)
  2. \(\left\{ {{\bf{0,11}}} \right\}\)
  3. \(\left\{ {{\bf{0,11,000}}} \right\}\)

Short Answer

Expert verified

1. Therefore, the nondeterministic finite-state automata that recognize the set\(\left\{ {{\bf{\lambda ,0}}} \right\}\) are shown below.

2. Hence, the nondeterministic finite-state automata that recognize the set \(\left\{ {{\bf{0,11}}} \right\}\)are shown below.

3. So, the nondeterministic finite-state automata that recognize the set \(\left\{ {{\bf{0,11,000}}} \right\}\)are shown below.

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

General form

Finite-state automaton (Definition):A finite-state automaton \({\bf{M = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}{\bf{,F}}} \right)\) consists of a finite set S of states, a finite input alphabet I, a transition function f that assigns a next state to every pair of state and input (so that \({\bf{f:S \times I}} \to {\bf{S}}\)), an initial or start state \({{\bf{s}}_0}\), and a subset F of S consisting of final (or accepting states).

Designing Finite-State Automata:We often construct a finite-state automaton that recognizes a given set of strings by carefully adding states and transitions and determining which of these states should be final states. When appropriate we include states that can keep track of some of the properties of the input string, providing the finite-state automaton with limited memory.

A rule of regular expression represents a set:

\(\emptyset \)represents the empty set, that is, the set with no strings;

\({\bf{\lambda }}\)represents the set\(\left\{ {\bf{\lambda }} \right\}\), which is the set containing the empty string;

x represents the set \(\left\{ {\bf{x}} \right\}\) containing the string with one symbol x;

(AB)represents the concatenation of the sets represented by A and by B;

\(\left( {{\bf{A}} \cup {\bf{B}}} \right)\)represents the union of the sets represented by A and by B;

\({\bf{A*}}\) represents the Kleene closure of the sets represented by A.

02

Step 2: Construct the nondeterministic finite-state automata

Given, \(\left\{ {{\bf{\lambda ,0}}} \right\}\).

Assume that, \({{\bf{s}}_0}\)is the starting point.

\({{\bf{s}}_0}\)should be the last state because the machine should accept the empty string\({\bf{\lambda }}\).

If the input is a 0, we go to the next final state, \({{\bf{s}}_1}\) (since 0 should be accepted).

Note: If you use a loop with input 0 at\({{\bf{s}}_0}\), all strings that solely contain 0s will be accepted.

The strings \({\bf{\lambda }}\) and 0 will be recognised by the nondeterministic finite-state automaton that results (but no other strings).

So, the diagram of nondeterministic finite-state automaton is shown below.

03

Construct the nondeterministic finite-state automata

Given,\(\left\{ {{\bf{0,11}}} \right\}\).

Assume that, \({{\bf{s}}_0}\)is the starting point.

\({{\bf{s}}_0}\)should not be a final state because the machine should not accept the empty string\({\bf{\lambda }}\).

If the input is 0, we proceed to the final state \({{\bf{s}}_1}\) (since 0 should be recognized).

We go to a non-final state \({{\bf{s}}_2}\) if the input is 1 (since 1 should not be recognized). We shift to the final state \({{\bf{s}}_1}\) if the following input is a 1 once again (as 11 should be recognized).

The strings 0 and 11 will be recognised by the nondeterministic finite-state automaton that results (but no other strings).

So, the diagram of nondeterministic finite-state automaton is shown below.

04

Construct the nondeterministic finite-state automata

Given,\(\left\{ {{\bf{0,11,000}}} \right\}\).

Assume that, \({{\bf{s}}_0}\)is the starting point.

\({{\bf{s}}_0}\)should not be a final state because the machine should not accept the empty string\({\bf{\lambda }}\).

If the input is 0, we proceed to the final state \({{\bf{s}}_1}\) (since 0 should be recognized). If the next input is another 0, we go to a non-final state \({{\bf{s}}_2}\) (because 00 should be recognised), and if the next input is another 0, we switch to a final state \({{\bf{s}}_3}\) (such that 000 will be recognized).

Note that if you return to \({{\bf{s}}_1}\) instead of\({{\bf{s}}_3}\), any string with an odd number of 0s and no 1s will be recognised.

We go to a non-final state \({{\bf{s}}_4}\) if the input is 1 (since 1 should not be recognized). We shift to the final state \({{\bf{s}}_3}\) if the following input is a 1 once again (as 11 should be recognized).

The strings 0, 11 and 000 will be recognised by the nondeterministic finite-state automaton that results (but no other strings).

So, the diagram of deterministic finite-state automaton is shown below.

One App. One Place for Learning.

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

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free