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

Find finite-state automata that recognize these sets of strings of \({\bf{0's}}\) and \({\bf{1's}}\).

\({\bf{(a)}}\)the set of all strings that start with no more than three consecutives \({\bf{0's}}\) and contain at least two consecutives \({\bf{1's}}\)

\({\bf{(b)}}\)the set of all strings with an even number of symbols that do not contain the pattern 101

\({\bf{(c)}}\)the set of all strings with at least three blocks of two or more \({\bf{1's}}\) and at least two \({\bf{0's}}\)

Short Answer

Expert verified

(a) Let \({S_0}\) be the start state of the finite-state automata. Let us defined the states as:

\({S_0}\)= At least 0 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_1} = \)At least 1 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_2} = \)At least 2 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_3} = \)At least 0 consecutives \(1's\) and at most 1 consecutives \(0's\).

(b) Let \({S_0}\) be the start state of the finite-state automata. Let us defined the states as:

\({S_0} = \)Even number of symbols and does not contain the pattern 101

\({s_1} = \)Odd number of symbols and does not contain the pattern 101

\({s_2} = \)An even number of symbols, does not contain the pattern 101, and ends with 1 (but not 101)

(c) Let \({S_0}\) be the start state of the finite-state automata. Let us defined the states as:

\({S_0} = \)At least zero \(0's\), 0 blocks of at least two \(1's\), string ends with 0 or is empty

\({s_1} = \)At least one \(0's\), 0 blocks of at least two \(1's\), string ends with 0

\({s_2} = \) At least two \(0's\), 0 blocks of at least two \(1's\), string ends with 0

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

Definition

A finite-state automaton \(M = \left( {S,I,f,{s_0},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 \({S_0}\), and a subset F of S consisting of final (or accepting states).

02

(a) Finding the finite-state automata

Let \({S_0}\) be the start state of the finite-state automata. Let us defined the states as:

\({S_0}\)= At least 0 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_1} = \)At least 1 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_2} = \)At least 2 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_3} = \)At least 0 consecutives \(1's\) and at most 1 consecutives \(0's\).

\({s_4} = \)At least 1 consecutives \(1's\) and at most 1 consecutives \(0's\).

\({s_5} = \)At least 2 consecutives \(1's\) and at most 1 consecutives \(0's\).

\({s_6} = \)At least 0 consecutives \(1's\) and at most 2 consecutives \(0's\).

\({s_7} = \)At least 1 consecutives \(1's\) and at most 2 consecutives \(0's\).

\({s_8} = \) At least 2 consecutives \(1's\) and at most 2 consecutives \(0's\).

03

Finding the finite-state automata

\({s_9} = \)At least 0 consecutives \(1's\) and at most 3 consecutives \(0's\).

\({s_{10}} = \)At least 1 consecutives \(1's\) and at most 3 consecutives \(0's\).

\({s_{11}} = \)At least 2 consecutives \(1's\) and at most 3 consecutives \(0's\).

If the input at state \({s_i}\) is 1, then you move to state \({s_{\left\{ {i + 1} \right\}}}\) if \({\bf{i}}\,{\bf{mod}}\,3 \ne 2\) and you remain at state \({s_i}\) when \(i\,mod\,3 = 2\).

If the input at state \({s_i}\) is 0, then you move to state \({s_{\left\{ {i + 3} \right\}}}\) if \({\bf{i}} \le 8\)

Note that the states \({s_2},{s_5},{s_8}\) and \({s_{11}}\) need to be the final states as they have at least two consecutives \(1's\) and at most three consecutives \(0's\).

Therefore, the states defined as:

\({S_0} = \)At least 0 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_1} = \)At least 1 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_2} = \)At least 2 consecutives \(1's\) and at most 0 consecutives \(0's\).

\({s_3} = \) At least 0 consecutives \(1's\) and at most 1 consecutives \(0's\).

04

(b) Finding the finite-state automata 

Let \({S_0}\) be the start state of the finite-state automata. Let us defined the states as:

\({S_0} = \)Even number of symbols and does not contain the pattern 101

\({s_1} = \)Odd number of symbols and does not contain the pattern 101

\({s_2} = \)An even number of symbols, does not contain the pattern 101, and ends with 1 (but not 101)

\({s_3} = \)An odd number of symbols, does not contain the pattern 101, and ends with 1 (but not 101)

\({s_4} = \)An even number of symbols, doesn’t contain the pattern 101, and ends with 10

\({s_5} = \)An even number of symbols, doesn’t contain the pattern 101, and ends with 10

If you have some input at state \({s_i}\) with i even, then you move to some state with i odd.

If you have some input at state \({s_i}\) with i odd, then you move to some state with i even.

05

Finding the finite-state automata 

If the input at state \({s_0}\) or \({s_1}\) is 1, then you move to state \({s_3}\) or \({s_2}\) respectively.

If the input at state \({s_0}\) or \({s_1}\) is 0, then you move to state \({s_1}\) or \({s_0}\) respectively.

If the input at state \({s_2}\) or \({s_3}\) is 0, then you move to state \({s_5}\) or \({s_4}\) respectively.

If the input at state \({s_2}\) or \({s_3}\) is 1, then you move to state \({s_3}\) or \({s_2}\) respectively.

If the input at state \({s_4}\) or \({s_5}\) is 1, then then the string should not be recognized as the string contains the pattern 101.

If the input at state \({s_4}\) or \({s_5}\) is 0, then you move to state \({s_1}\) or \({s_0}\) respectively.

Note that the states \({s_0}\), \({s_2}\) and \({s_4}\) need to be the final states as they have an even number of symbols and do not contain the pattern 101.

Therefore, the states defined as:

\({S_0} = \)Even number of symbols and doesn’t contain the pattern 101

\({s_1} = \)The odd number of symbols and doesn’t contain the pattern 101

\({s_2} = \)An even number of symbols, doesn’t contain the pattern 101, and ends with 1 (but not 101)

06

(c) Finding the finite-state automata

Let \({S_0}\) be the start state of the finite-state automata. Let us defined the states as:

\({S_0} = \)At least zero \(0's\), 0 blocks of at least two \(1's\), string ends with 0 or is empty

\({s_1} = \)At least one \(0's\), 0 blocks of at least two \(1's\), string ends with 0

\({s_2} = \)At least two \(0's\), 0 blocks of at least two \(1's\), string ends with 0

\({s_3} = \)At least zero \(0's\), 0 blocks of at least two \(1's\), string ends with 1

\({s_4} = \)At least one \(0's\), 0 blocks of at least two \(1's\), string ends with 1

\({s_5} = \)At least two \(0's\), 0 blocks of at least two \(1's\), string ends with 1

\({s_6} = \)At least zero \(0's\), 1 block of at least two \(1's\), string ends with 1

\({s_7} = \)At least one \(0's\), 1 block of at least two \(1's\), string ends with 1

\({s_8} = \)At least two \(0's\), 1 block of at least two \(1's\), string ends with 1

\({s_9} = \)At least one \(0's\), 1 block of at least two \(1's\), string ends with 0

\({s_{10}} = \)At least two \(0's\), 1 block of at least two \(1's\), string ends with 0

\({s_{11}} = \) At least one \(0's\), 1 block of at least two \(1's\), string ends with 01

07

Finding the finite-state automata

\({s_{12}} = \)At least two \(0's\), 1 block of at least two \(1's\), string ends with 01

\({s_{13}} = \)At least one \(0's\), 2 blocks of at least two \(1's\), string ends with 1

\({s_{14}} = \)At least two \(0's\), 2 blocks of at least two \(1's\), string ends with 1

\({s_{15}} = \)At least two \(0's\), 2 blocks of at least two \(1's\), string ends with 0

\({s_{16}} = \)At least two \(0's\), 2 blocks of at least two \(1's\), string ends with 01

\({s_{17}} = \)At least two \(0's\), at least 3 blocks of at least two \(1's\)

The transitions from state to state are determined by how you defined the different states.

Note that \({s_{15}}\) needs to be a final state as this state corresponds with the strings with at least three blocks of two or more \(1's\) and at least two \(0's\).

Therefore, the states defined as:

\({S_0} = \)At least zero \(0's\), 0 blocks of at least two \(1's\), string ends with 0 or is empty

\({s_1} = \)At least one \(0's\), 0 blocks of at least two \(1's\), string ends with 0

\({s_2} = \) At least two \(0's\), 0 blocks of at least two \(1's\), string ends with 0

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