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

Explain why the Turing machine in Example \(3\) recognizes a bit string if and only if this string is of the form \({{\bf{0}}^{\bf{n}}}{{\bf{1}}^{\bf{n}}}\) for some positive integer \({\bf{n}}\).

Short Answer

Expert verified

Need to play with this machine to get a feel for what is going on. After doing \({{\bf{s}}_{\bf{0}}}\), you will understand that it operates as follows. If the input string is blank or starts with a \({\bf{1}}\), then the machine halts in state \({{\bf{s}}_{\bf{0}}}\), which is not final, and therefore every such string is not accepted (which is a good thing, since it is not in the set to be recognized).

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)\) consists of a finite set \({\bf{S}}\) of states, an alphabet \({\bf{I}}\) containing the blank symbol \({\bf{B}}\), a partial function \({\bf{f}}\) from \({\bf{S \times I}}\) to \({\bf{S \times I \times \{ R,L\} }}\), and a starting state \({{\bf{s}}_{\bf{0}}}\).

To understand what is happening, it must experiment with this contraption. Once it completes\({{\bf{s}}_{\bf{0}}}\), it will realize how it functions. Every such string is rejected since the machine halts at state \({{\bf{s}}_{\bf{0}}}\), which is not final if the input string is blank or starts with a \({\bf{1}}\). (Which is a good thing, since it is not in the set to be recognized). Otherwise the initial \(0\) is changed to an \(M\), and the machine skips past all the intervening \(0's\) and \({\bf{1}}'s\) until it either comes to the end of the input string or else comes to an \(M\) (which, as it will see, has been written over the right-most remaining bit). At this point it backs up (moves left) one square and is in state \({{\bf{s}}_{\bf{2}}}\). Since the acceptable strings must have a \({\bf{1}}\) at the right for each \(0\) at the left, there had better be a \({\bf{1}}\) here if the string is acceptable. Therefore, the only transition out of state \({{\bf{s}}_{\bf{2}}}\) occurs when this square contains a \({\bf{1}}\).

02

The string is of the form\({{\bf{0}}^{\bf{n}}}{{\bf{1}}^{\bf{n}}}\)for some positive integer\({\bf{n}}\).

If it does, then the machine replaces it with an \(M\), and makes its way back to the left. (If this square does not contain a \({\bf{1}}\), then the machine halts in the nonfinal state \({{\bf{s}}_{\bf{2}}}\), as appropriate.) On its way back, it stays in state \({{\bf{s}}_3}\) as long as it sees \({\bf{1}}'s\), then stays in \({{\bf{s}}_4}\) as long as it sees \(0's\). Eventually either it encounters a \({\bf{1}}\) while in state \({{\bf{s}}_4}\), at which point it (appropriately) halts without accepting (since the string had a \(0\) to the right of a \({\bf{1}}\)); or else it reaches the right-most \(M\) that had been written over a \(0\) near the beginning of the string. If it is in state \({{\bf{s}}_3}\) when this happens, then there are no more \(0's\) in the string, so it had better be the case (if it want to accept this string) that there are no more \({\bf{1}}'s\) either; this is accomplished by the transitions \(\left( {{{\bf{s}}_{\bf{3}}}{\bf{,M,}}{{\bf{s}}_{\bf{5}}}{\bf{,M,R}}} \right)\) and \(\left( {{{\bf{s}}_{\bf{5}}}{\bf{,M,}}{{\bf{s}}_{\bf{6}}}{\bf{,M,R}}} \right)\), and \({{\bf{s}}_{\bf{6}}}\) is a final state.

Otherwise, the machine halts in nonfinal state \({{\bf{s}}_5}\). If it is in state \({{\bf{s}}_4}\) when this \(M\) is encountered, then it needs to start all over again, except that now the string will have had its left-most remaining \(0\) and its right-most remaining \({\bf{1}}\) replaced by \(M's\). So, the machine moves (staying in state \({{\bf{s}}_4}\)) to the left-most remaining \(0\) and goes back into state \({{\bf{s}}_{\bf{0}}}\) to repeat the process.

It needs to play with this machine to get a feel for what is going on. After doing \({{\bf{s}}_{\bf{0}}}\), it will understand that it operates as follows. If the input string is blank or starts with a \({\bf{1}}\), then the machine halts in state \({{\bf{s}}_{\bf{0}}}\), which is not final.

Therefore, every such string is not accepted.

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