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 an even number of \({\bf{1's}}\).

Short Answer

Expert verified

The constructed Turing machine that recognizes the set of all bit strings that contain an even number of \({\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}}_{\bf{0}}}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,1,}}{{\bf{s}}_{\bf{1}}}{\bf{,1,R}}} \right)\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,B,}}{{\bf{s}}_{\bf{2}}}{\bf{,B,R}}} \right)\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,0,}}{{\bf{s}}_{\bf{1}}}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,1,}}{{\bf{s}}_{\bf{2}}}{\bf{,1,R}}} \right)\\\left( {{{\bf{s}}_{\bf{2}}}{\bf{,0,}}{{\bf{s}}_{\bf{2}}}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{2}}}{\bf{,1,}}{{\bf{s}}_{\bf{1}}}{\bf{,1,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

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 \(S{\bf{ \times I}}\) to \({\bf{S \times I \times }}\{ R,L\} \). Note: The partial function \({\bf{f}}\) is often represented as \(5{\bf{ - }}\)tuples.

It will require \(2\) states \({{\bf{s}}_{\bf{0}}}\), \({{\bf{s}}_{\bf{1}}}\) and \({{\bf{s}}_{\bf{2}}}\)\({{\bf{s}}_{\bf{0}}}\) is the start state which represents that there are zero \({\bf{1's}}\), \({{\bf{s}}_{\bf{1}}}\) will be the state that indicates that there are an odd number of \({\bf{1's}}\) in the string, and \({{\bf{s}}_{\bf{2}}}\) will be the final state and will represent that there are an even number of \({\bf{1's}}\)), 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 \(0,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}}_{\bf{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 an odd number of \({\bf{1's}}\).

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

If the input is a blank \({\bf{B}}\), then it moves to the state \({{\bf{s}}_{\bf{2}}}\) as the string then contains no \({\bf{1}}\)'s and thus there are an even number of \({\bf{1's}}\).

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

03

Defining the partial function as five-tuples

Once you are at state \({{\bf{s}}_{\bf{1}}}\), you know that there are an odd number of \({\bf{1's}}\). If the input is a \({\bf{0}}\), then you 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{1}}}{\bf{,0,}}{{\bf{s}}_{\bf{1}}}{\bf{,0,R}}} \right)\)

If the input is a \({\bf{1}}\), then it moves to the final state \({{\bf{s}}_{\bf{2}}}\) such that the string will be accepted (as now it knows that the string contains an even number of \({\bf{1's}}\)).

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

Once itis at state \({{\bf{s}}_{\bf{2}}}\), it knows that there are an even number of \({\bf{1's}}\). If the input is a \({\bf{0}}\), then 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{2}}}{\bf{,0,}}{{\bf{s}}_{\bf{2}}}{\bf{,0,R}}} \right)\)

04

Defining the partial function as five-tuples

If the input is a \({\bf{1}}\), then it will move back to state \({{\bf{s}}_{\bf{1}}}\) as there are then an odd number of \({\bf{1's}}\).

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

If it comes across a blank \({\bf{B}}\) while in state \({{\bf{s}}_{\bf{2}}}\), then machine needs to halt as it knows that the string contains an even number of \({\bf{1's}}\). This will occur when it does not add a five-tuple that has \({{\bf{s}}_{\bf{2}}}\) as its first coordinate and \({\bf{B}}\) as its second coordinate.

Note that the machine will halt in the final state \({{\bf{s}}_{\bf{2}}}\) when the string contains an even number of ones, which implies that all bit strings with an even number of \({\bf{1's}}\) will be recognized. However, if the string contains an odd number of \({\bf{1's}}\), then the machine will halt in the non-final states \({{\bf{s}}_{\bf{1}}}\) such that the strings are not recognized.

Therefore, the constructed Turing machine that recognizes the set of all bit strings that contain an even number of\({\bf{1's}}\)is

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