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 with tape symbols \(0,1\), and \(B\) that, given a bit string as input, replaces all but the leftmost \(1\)on the tape with \(0's\) and does not change any of the other symbols on the tape.

Short Answer

Expert verified

The constructed Turing machine with tape symbols\(0,1\), and\(B\)that, given a bit string as input, replaces all but the leftmost\(1\)on the tape with\(0's\)and does not change any of the other symbols on the tape 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}}}} \right\}\\{\bf{I = \{ 0,1,B\} }}\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,0,}}{{\bf{s}}_{\bf{1}}}{\bf{,0,R}}} \right)\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,1,}}{{\bf{s}}_{\bf{0}}}{\bf{,1,R}}} \right)\\\left( {{{\bf{s}}_{\bf{0}}}{\bf{,B,}}{{\bf{s}}_{\bf{1}}}{\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{1}}}{\bf{,0,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}}}\) and \({{\bf{s}}_{\bf{1}}}\)(\({{\bf{s}}_{\bf{0}}}\) is the start state, \({{\bf{s}}_{\bf{1}}}\) 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}}}} \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 \(0\), it will keep the input unchanged and move one position to the right (as it only want to change the \(1's\)).

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

The first time the input is a \(1\), it moves to the state \({{\bf{s}}_{\bf{1}}}\) and keep the \(1\) unchanged. Thenis moves one position to the right.

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

Once it arrives at the first blank symbol (while not having read any \(1's\)), it will move to the final state \({{\bf{s}}_{\bf{1}}}\) as it reads the entire string.

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

Once itis at state \({{\bf{s}}_{\bf{1}}}\), itis either at the end of the string or the first \(1\) has occurred in the string. Then it needs to change all remaining \(1's\) to \(0's\).

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

If itis at state \({{\bf{s}}_{\bf{1}}}\) and have the input \(0\), then it will just move one position to the right (such that it can search for remaining \(1's\) in the string).

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

03

Defining the partial function as five-tuples

Once it comes across a blank \({\bf{B}}\) and are in the final state \({{\bf{s}}_{\bf{1}}}\), the machine will need to halt. This will occur when you do not add a five-tuple that has \({{\bf{s}}_{\bf{1}}}\) as its first coordinate and \({\bf{B}}\) as its second coordinate.

Hence, the constructed Turing machine with tape symbols\(0,1\), and\(B\)that, given a bit string as input, replaces all but the leftmost\(1\)on the tape with\(0's\)and does not change any of the other symbols on the tape is

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

Show that the grammar \({\bf{G = }}\left( {{\bf{V, T, S, P}}} \right)\) with \({\bf{V = }}\left\{ {{\bf{0, S}}} \right\}{\bf{, T = }}\left\{ {\bf{0}} \right\}\), starting state \({\bf{S}}\), and productions \({\bf{S}} \to {\bf{0S}}\) and \({\bf{S}} \to 0\) is unambiguous.

Suppose that A is a subset of\({{\bf{V}}^{\bf{*}}}\)where V is an alphabet.Prove or disprove each of these statements.

\(\begin{array}{l}{\bf{a)}}\,\,{\bf{A}} \subseteq {{\bf{A}}^{\bf{2}}}\\{\bf{b)}}\,\,{\bf{if}}\,{\bf{A = }}{{\bf{A}}^{\bf{2}}}{\bf{,then}}\,{\bf{\lambda }} \in {\bf{A}}\\{\bf{c)}}\,\,{\bf{A\{ \lambda \} = A}}\\{\bf{d)}}\,\,{{\bf{(}}{{\bf{A}}^{\bf{*}}}{\bf{)}}^{\bf{*}}}{\bf{ = }}{{\bf{A}}^{\bf{*}}}\\{\bf{e)}}\,\,{{\bf{A}}^{\bf{*}}}{\bf{A = }}{{\bf{A}}^{\bf{*}}}\\{\bf{f)}}\,\,\left| {{{\bf{A}}^{\bf{n}}}} \right|{\bf{ = }}{\left| {\bf{A}} \right|^{\bf{n}}}\end{array}\)

use top-down parsing to determine whether each of the following strings belongs to the language generated by the grammar in Example 12.

\(\begin{array}{*{20}{l}}{{\bf{a) baba}}}\\{{\bf{b) abab}}}\\{{\bf{c) cbaba}}}\\{{\bf{d) bbbcba}}}\end{array}\)

Show that these equalities hold.

a) \({{\bf{\{ \lambda \} }}^{\bf{*}}}{\bf{ = \{ \lambda \} }}\)

b) \({\bf{(A*)* = A*}}\) for every set of strings A.

Construct phrase-structure grammars to generate each of these sets.

a) \(\left\{ {\left. {{{\bf{0}}^{\bf{n}}}} \right|{\bf{n}} \ge {\bf{0}}} \right\}\)

b) \(\left\{ {\left. {{{\bf{1}}^{\bf{n}}}{\bf{0}}} \right|{\bf{n}} \ge {\bf{0}}} \right\}\)

c) \(\left\{ {\left. {{{\left( {{\bf{000}}} \right)}^{\bf{n}}}} \right|{\bf{n}} \ge {\bf{0}}} \right\}\)

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