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 a Turing machine that recognizes the set of all bit strings that contain at least two \({\bf{1's}}\).

Short Answer

Expert verified

The constructed Turing machine that recognizes the set of all bit strings that contain at least two\({\bf{1's}}\)is

\(\begin{array}{c}{\bf{T = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}} \right)\\{\bf{S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}} \right\}\\{\bf{I = \{ 0,1,B\} }}\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,0,}}{{\bf{s}}_0}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,1,}}{{\bf{s}}_1}{\bf{,1,R}}} \right)\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,0,}}{{\bf{s}}_1}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,1,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}1{\bf{,R}}} \right)\end{array}\)

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

Step \({\bf{1}}\): Definition

A Turing machine \({\bf{T = }}\left( {{\bf{S,I,f,}}{{\bf{s}}_{\bf{0}}}} \right)\) contains a finite set \({\bf{S}}\) of states, an alphabet \({\bf{I}}\) containing the blank symbol \({\bf{B}}\), a starting state \({{\bf{s}}_{\bf{0}}}\) and a partial function from \({\bf{S \times I}}\) to \({\bf{S \times I \times \{ R,L\} }}\). Note: The partial function \({\bf{f}}\) is often represented as \({\bf{5}}\)-tuples.

It will require \(3\) states \({{\bf{s}}_{\bf{0}}}\), \({{\bf{s}}_{\bf{1}}}\) and \({{\bf{s}}_2}\left( {{{\bf{s}}_{\bf{0}}}} \right)\) is the start state which represents that there was no \({\bf{1}}\) yet in the input, \({{\bf{s}}_{\bf{1}}}\) will be the state that indicates that one \({\bf{1}}\) has found in the string, and \({{\bf{s}}_2}\) will be the final state), which will be contained in the set \({\bf{S}}\).

\({\bf{S = }}\left\{ {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}} \right\}\)

The alphabet \({\bf{I}}\) needs to contain the tape symbols. The tape symbols are given as \({\bf{0}}\),\({\bf{1}}\) and \({\bf{B}}\).

\({\bf{I = \{ 0,1,B\} }}\)

02

Defining the partial function as five tuples

Next, it will define the partial function as five tuples.

As long as the input is a \({\bf{0}}\), it will keep the input unchanged and move one position to the right (as you are only interested in the \({\bf{1's}}\)).

\(\left( {{{\bf{s}}_{\bf{0}}}{\bf{,0,}}{{\bf{s}}_0}{\bf{,0,R}}} \right)\)

If the input is a \({\bf{1}}\), then it moves to the state \({{\bf{s}}_{\bf{1}}}\) as it knows that the string contains at least one \({\bf{1}}\).

\(\left( {{{\bf{s}}_{\bf{0}}}{\bf{,1,}}{{\bf{s}}_1}{\bf{,1,R}}} \right)\)

Once itis at state \({{\bf{s}}_{\bf{1}}}\), you know that the first \({\bf{1}}\) was found in the input. If the input is a \({\bf{0}}\), then it will keep the input unchanged and move one position to the right (as itis only interested in the \({\bf{1's}}\)).

\(\left( {{{\bf{s}}_{\bf{1}}}{\bf{,0,}}{{\bf{s}}_1}{\bf{,0,R}}} \right)\)

03

Defining the partial function as five tuples

If the input is a \({\bf{1}}\), then it moves to the final state \({{\bf{s}}_2}\) such that the string will be accepted (as it knows that the string contains at least two \({\bf{1's}}\)).

\(\left( {{{\bf{s}}_{\bf{1}}}{\bf{,1,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}1{\bf{,R}}} \right)\)

Once itis in the final state \({{\bf{s}}_2}\), the machine will need to halt as it knows that the string contains at least two \({\bf{1's}}\). This will occur when it does not add a five-tuple that has \({{\bf{s}}_2}\) as its first coordinate.

Note that the machine will halt in the final state \({{\bf{s}}_2}\) when the string contains at least two ones, which implies that all bit strings with at least two \({\bf{1's}}\) will be recognized. However, if the string contains not at least two ones, then the machine will halt in one of the non-final states \({{\bf{s}}_{\bf{0}}}\) or \({{\bf{s}}_{\bf{1}}}\) such that the strings are not recognized.

Hence, the constructed Turing machine that recognizes the set of all bit strings that contain at least two\({\bf{1's}}\)is

\(\begin{array}{c}\left( {{{\bf{s}}_{\bf{0}}}{\bf{,0,}}{{\bf{s}}_0}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,1,}}{{\bf{s}}_1}{\bf{,1,R}}} \right)\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,0,}}{{\bf{s}}_1}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,1,}}{{\bf{s}}_{\bf{2}}}{\bf{,}}1{\bf{,R}}} \right)\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

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