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 computes the function \(f\left( {{n_1},{n_2}} \right) = \max \left( {{n_1},{n_2}} \right)\).

Short Answer

Expert verified

The constructed Turning machine is

\(\begin{array}{l}\left( {{s_0},0,{s_0},0,R} \right),\left( {{s_0},{s_5},B,L} \right),\left( {{s_5},0,{s_5},B,L} \right),\left( {{s_5},B,{s_6},B,R} \right),\left( {{s_6},B,{s_6},B,R} \right),\\\left( {{s_6},0,{s_7},l,R} \right),\left( {{s_7},0,{s_7},l,R} \right),\left( {{s_7},l,{s_7},l,R} \right),\left( {{s_0},l,} \right.\left. {{s_1},0,R} \right),\left( {{s_1},l,{s_1},l,R} \right),\\\left( {{s_1},{s_2}{,^*},R} \right),\left( {{s_2},0,{s_2},0,R} \right),\left( {{s_2},l,{s_3},0,L} \right),\left( {{s_2},B,{s_4},B,L} \right),\left( {{s_3}{,^*},{s_3}{,^*},L} \right),\\\left( {{s_3},0,{s_3},0,L} \right),\left( {{s_3},l,{s_3},l,L} \right),\left( {{s_3},B,{s_0},B,} \right.R),\left( {{s_4},0,{s_4},B,L} \right),\left( {{s_4}{,^*},{s_8},B,L} \right),\\\left( {{s_8},0,{s_8},l,L} \right),\left( {{s_8},l,{s_8},l,L} \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 \(T = \left( {S,I,f,{s_0}} \right)\) consists of a finite set \(S\) of states, an alphabet \(I\) containing the blank symbol \(B\), a partial function \(f\) from \(S \times I\) to \(S \times I \times {\rm{\{ }}R,L{\rm{\} }}\), and a starting state \({s_0}\).

02

Using the first and second input

The idea here is to match off the \(1's\) in the two inputs (changing the \(1's\) to \(0's\) from the left, say, to keep track), until one of them is exhausted. At that point, you need to erase the smaller input entirely (as well as the asterisk) and change the \(0's\) back to \(1's\). Here is how you'll do it. In state \({s_0}\) you skip over any \(0's\) until you come to either a \(I\) or the \(*\). If it's the \(*\), then you know that the second input \(\left( {{n_2}} \right)\) is at least as large as the first \(\left( {{n_1}} \right)\), so you enter a clean-up state \({s_5}\), which erases the asterisk and all the \(0's\) and \(1's\) to its left. The five-tuples for this much are \(\left( {{s_0},0,{s_0},0,R} \right),\left( {{s_0}{,^*},{s_5},\;B,\;L} \right)\), and \(\left( {{s_5},0,{s_5},\;B,\;L} \right)\). Once this erasing is finished, you need to go over to the part of the tape where the second input was and change all the \(0's\) back to \(1's\) the following transitions accomplish this: \(\left( {{s_5},\;B,{s_6},\;B,R} \right),\left( {{s_6},\;B,{s_6},\;B,R} \right),\left( {{s_6},0,{s_7},l,R} \right),\left( {{s_7},0,{s_7},l,R} \right)\) and \(\left( {{s_7},l,{s_7},l,R} \right)\). Eventually the machine halts in state \({s_7}\) when the blank following the original input is encountered.

03

Constructing the Turning machine

The other possibility is that the machine encounters a \(1\) while in state so. You want to change this \(1\) to a \(0\), skip over any remaining \(1's\) as well as the asterisk, skip over any \(0's\) to the right of the asterisk (these represent parts of \({n_2}\) that have already been matched off against equal parts of \({n_1}\)), and then either find a \(1\) in \({n_2}\)) (which you change to a \(0\) ) or else come to the blank at the end of the input. Here are the transitions: \(\left( {{s_0},1,{s_1},0,R} \right),\left( {{s_1},1,{s_1},1,R} \right),\left( {{s_{1,}}{s_{2,}}R} \right),\left( {{s_2},0,{s_2},0,R} \right),\left( {{s_2},1,{s_3},0,\;L} \right),\left( {{s_2},\;B,{s_4}} \right.,B,L)\). At this point you are either in state \(83\), ready to go back for the next iteration, or in state \(84\) ready for some cleanup. In the former case, you want to skip back over the nonblank symbols until you reach the start of the string, so you add five-tuples \(\left( {{s_3}{,^*},{s_3}{,^*},\;L} \right),\left( {{s_3},0,{s_3},0,\;L} \right),\left( {{s_3},l,{s_3},l,L} \right)\), and \(\left( {{s_3},\;B,{s_0},\;B,R} \right)\). In the latter case, you know that the first string is longer than the second. Therefore, you want to erase remnants of the second input string and the asterisk, and change the \(0's\) in the first input string back to \(1's\). Here are the transitions: \(\left( {{s_4},0,{s_4},\;B,\;L} \right),\left( {{s_4}{,^*},{s_8},\;B,\;L} \right),\left( {{s_8},0,{s_8},l,L} \right),\left( {{s_8},1,{s_8},l,L} \right)\).

Therefore, the constructed Turning machine is:

\(\begin{array}{l}\left( {{{\bf{s}}_{\bf{0}}}{\bf{,0,}}{{\bf{s}}_{\bf{0}}}{\bf{,0,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{0}}}{\bf{,}}{{\bf{s}}_{\bf{5}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{5}}}{\bf{,0,}}{{\bf{s}}_{\bf{5}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{5}}}{\bf{,B,}}{{\bf{s}}_{\bf{6}}}{\bf{,B,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{6}}}{\bf{,B,}}{{\bf{s}}_{\bf{6}}}{\bf{,B,R}}} \right){\bf{,}}\\\left( {{{\bf{s}}_{\bf{6}}}{\bf{,0,}}{{\bf{s}}_{\bf{7}}}{\bf{,l,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{7}}}{\bf{,0,}}{{\bf{s}}_{\bf{7}}}{\bf{,l,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{7}}}{\bf{,l,}}{{\bf{s}}_{\bf{7}}}{\bf{,l,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{0}}}{\bf{,l,}}} \right.\left. {{{\bf{s}}_{\bf{1}}}{\bf{,0,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{1}}}{\bf{,l,}}{{\bf{s}}_{\bf{1}}}{\bf{,l,R}}} \right){\bf{,}}\\\left( {{{\bf{s}}_{\bf{1}}}{\bf{,}}{{\bf{s}}_{\bf{2}}}{{\bf{,}}^{\bf{*}}}{\bf{,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{2}}}{\bf{,0,}}{{\bf{s}}_{\bf{2}}}{\bf{,0,R}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{2}}}{\bf{,l,}}{{\bf{s}}_{\bf{3}}}{\bf{,0,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{2}}}{\bf{,B,}}{{\bf{s}}_{\bf{4}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{3}}}{{\bf{,}}^{\bf{*}}}{\bf{,}}{{\bf{s}}_{\bf{3}}}{{\bf{,}}^{\bf{*}}}{\bf{,L}}} \right){\bf{,}}\\\left( {{{\bf{s}}_{\bf{3}}}{\bf{,0,}}{{\bf{s}}_{\bf{3}}}{\bf{,0,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{3}}}{\bf{,l,}}{{\bf{s}}_{\bf{3}}}{\bf{,l,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{3}}}{\bf{,B,}}{{\bf{s}}_{\bf{0}}}{\bf{,B,}}} \right.{\bf{R),}}\left( {{{\bf{s}}_{\bf{4}}}{\bf{,0,}}{{\bf{s}}_{\bf{4}}}{\bf{,B,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{4}}}{{\bf{,}}^{\bf{*}}}{\bf{,}}{{\bf{s}}_{\bf{8}}}{\bf{,B,L}}} \right){\bf{,}}\\\left( {{{\bf{s}}_{\bf{8}}}{\bf{,0,}}{{\bf{s}}_{\bf{8}}}{\bf{,l,L}}} \right){\bf{,}}\left( {{{\bf{s}}_{\bf{8}}}{\bf{,l,}}{{\bf{s}}_{\bf{8}}}{\bf{,l,L}}} \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

Study anywhere. Anytime. Across all devices.

Sign-up for free