Исполнитель МТ представляет собой читающую и записывающую головку, которая может передвигаться вдоль бесконечной горизонтальной ленты, разделённой на равные ячейки. В каждой ячейке находится ровно один символ из алфавита исполнителя (множество символов включая специальный пустой символ a0.
Время работы исполнителя делится на дискретные такты (шаги). На каждом такте головка МТ находится в одном из множества допустимых состояний В начальный момент времени головка находится в начальном состоянии q0.
На каждом такте головка обозревает одну ячейку ленты, называемую текущей ячейкой. За один такт головка исполнителя может заменить символ в текущей ячейке (или оставить символ неизменным) и переместиться в ячейку справа или слева от текущей (или остаться в той же ячейке). После каждого такта головка переходит в новое состояние или остаётся в прежнем состоянии.
Программа работы исполнителя МТ задаётся в табличном виде.
| a0 | a1 | ... | ||
| q0 | команда | команда | ... | команда |
| q1 | команда | команда | ... | команда |
| ... | ... | ... | ... | ... |
| команда | команда | ... | команда |
В первой строке перечислены все возможные символы в текущей ячейке ленты, в первом столбце — возможные состояния головки. На пересечении i-й строки и j-го столбца находится команда, которую выполняет МТ, когда головка обозревает j-й символ, находясь в i-м состоянии. Если
Каждая команда состоит из трёх элементов, разделённых запятыми: первый элемент — записываемый в текущую ячейку символ алфавита (может совпадать с тем, который там уже записан). Второй элемент — один из четырёх символов «L», «R», «N», «S». Символы «L» и «R» означают сдвиг в левую или правую ячейки соответственно, «N» — отсутствие сдвига, «S» — завершение работы исполнителя МТ после выполнения текущей команды. Сдвиг происходит после записи символа в текущую ячейку. Третий элемент — новое состояние головки после выполнения команды.
Например,
Выполните задание.
На ленте исполнителя МТ в соседних ячейках записана последовательность из 999 символов, которая может включать только четверки, шестерки и восьмерки, расположенные в произвольном порядке. Ячейки справа и слева от последовательности заполнены пустыми символами «λ». В начальный момент времени головка расположена в ближайшей ячейке справа от последовательности. Программа для исполнителя:
| λ | 4 | 6 | 8 | 0 | 1 | |
| q0 | ||||||
| q1 |
Известно, что после выполнения программы получилась строка, в которой все соседние символы различны. Определите минимальное возможное значение суммы цифр в исходной строке.
Рассмотрим программу исполнителя МТ. Исполнитель находится в ближайшей ячейке справа от последовательности. Следовательно, исполнитель выполнит команду влево. Как только исполнитель встретит символ «λ», то программа исполнителя закончится.
Если встретит символ «4», то заменит его на символ «0» и перейдет в левую ячейку.
Если встретит символ «6», то заменит его на символ «0» и перейдет в левую ячейку.
Если встретит символ «8», то заменит его на символ «1» и перейдет в левую ячейку.
После обработки 999 символов Исполнитель остановится. Так как, после выполнения программы получилась строка, в которой все соседние символы различны, то в строке должно быть чередование символов «0» и «1». Следовательно, в исходной последовательности должно быть чередование символа «8» и одного любого символа из выбора «4» или «6».
Так как нам необходимо определить минимальное возможное значение суммы цифр в исходной строке, то в исходной строке должны быть только символы «4» и «8», при этом, для уменьшения суммы, последовательность должна начинаться и заканчиваться символом «4». Следовательно, в строке будет 500 символов «4» и 499 символов «8».
Минимальное возможное значение суммы цифр в исходной строке 500 · 4+499 · 8=5992
Ответ: 5992.

