
Помогите, пожалуйста! На ленте машины Поста расположен массив из 2n ячеек. Составить программу,
по которой машина Поста раздвинет на расстояние в одну ячейку две половины данного массива.

Ответы на вопрос

Идея возможного решения: по очереди будем оттаскивать в сторону по одной метке с каждой стороны. В итоге получатся две половины, разделенные двумя пустыми ячейками. Чтобы получить то, что надо, нужно сдвинуть одну половину в направлении другой.
Поясняющая картинка и программа (обозначения такие же, как в программе Полякова) в приложенных картинках,





Конечно, помогу! Для того чтобы машина Поста раздвинула на расстояние в одну ячейку две половины массива из 2n ячеек, нужно использовать следующую программу машины Поста:
- Переместиться в начало массива.
- Отметить начало первой половины массива.
- Переместиться в начало второй половины массива.
- Отметить начало второй половины массива.
- Переместиться в конец первой половины массива.
- Пока текущая ячейка не пуста (не содержит символа), переместиться вправо.
- Переместиться в начало первой половины массива.
- Пока текущая ячейка не пуста (не содержит символа), переместиться вправо.
- Переместиться в начало второй половины массива.
- Пока текущая ячейка не пуста (не содержит символа), переместиться вправо.
- Отметить начало первой половины массива.
- Переместиться в начало второй половины массива.
- Отметить начало второй половины массива.
- Переместиться в конец первой половины массива.
Теперь давайте представим символ "#" как маркер начала или конца половины массива. Допустим, у нас есть массив из 2n ячеек, где a, b, c и d - произвольные символы, а "#" - маркер начала или конца половины массива:
cssa b c d # a b c d #
Программа машины Поста будет выглядеть следующим образом (допустим, начальное состояние машины Поста находится на первой ячейке массива):
markdown1. > > * *
2. [ ]
3. > > > *
4. [ ]
5. < < < *
6. > > * *
7. < < < *
8. > > * *
9. < < < *
10. [ ]
11. > > * *
12. < < < *
13. [ ]
14. < < < *
Где:
>
- перейти в следующую ячейку вправо<
- перейти в следующую ячейку влево[ ]
- проверить текущую ячейку на пустоту*
- записать в текущую ячейку символ "*"
Эта программа переместит две половины массива на расстояние в одну ячейку. Необходимо убедиться, что символ "*" не встречается в исходном массиве, чтобы избежать конфликтов при выполнении программы.


Похожие вопросы
Топ вопросов за вчера в категории Информатика







Последние заданные вопросы в категории Информатика
-
Математика
-
Литература
-
Алгебра
-
Русский язык
-
Геометрия
-
Английский язык
-
Химия
-
Физика
-
Биология
-
Другие предметы
-
История
-
Обществознание
-
Окружающий мир
-
География
-
Українська мова
-
Информатика
-
Українська література
-
Қазақ тiлi
-
Экономика
-
Музыка
-
Право
-
Беларуская мова
-
Французский язык
-
Немецкий язык
-
МХК
-
ОБЖ
-
Психология
-
Физкультура и спорт
-
Астрономия
-
Кыргыз тили
-
Оʻzbek tili