Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
207 / 5 / 2
Регистрация: 27.04.2024
Сообщений: 72

Циклические Ханойские башни

03.05.2024, 20:11. Показов 1162. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В игру «Ханойские башни» добавлено новое ограничение – теперь диск со стержня 1 можно перекладывать только на стержень 2, со стержня 2 – только на стержень 3, а со стержня 3 – только на стержень 1 (то есть, диски можно перекладывать только «по кругу»).

Решите головоломку с учетом этого нового ограничения. Количество перекладываний не должно превышать 200000, при условии, что количество дисков не превосходит 10.

Формат входных данных
На вход программе дается натуральное число
n (n≤10) – количество дисков.

Формат результата
Требуется вывести список перекладываний в формате: номер кольца, исходный стержень, конечный стержень (по одному перекладыванию в строке). Количество перекладываний не должно превосходить 200000.

Примеры
Входные данные
2
Результат работы
1 1 2
1 2 3
2 1 2
1 3 1
2 2 3
1 1 2
1 2 3


Тема Рекурсия
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.05.2024, 20:11
Ответы с готовыми решениями:

Ханойские башни
Ниже представлен текст одной из классических головоломок и по совместительству алгоритмических задач по программированию. С ней знакомы...

Ханойские башни
Написать программу, которая считывает сколько дисков нужно переложить и выводит последовательность перекладываний.

Ханойские башни
Ханойские башни python 3.2.5 ограничение по времени на тест2 секунды ограничение по памяти на тест64 мегабайта ввод стандартный ввод ...

2
9 / 7 / 2
Регистрация: 07.05.2024
Сообщений: 75
07.05.2024, 12:19
Лучший ответ Сообщение было отмечено utsushi как решение

Решение

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
def move(n, start, finish):
    if n > 0:
        tmp = 6 - start - finish
        if (finish - start) % 3 == 1:
            move(n - 1, start, tmp)
            print(n, start, finish)
            move(n - 1, tmp, finish)
        else:
            move(n - 1, start, finish)
            print(n, start, tmp)
            move(n - 1, finish, start)
            print(n, tmp, finish)
            move(n - 1, start, finish)
 
n= int(input())
move(n, 1,3)
1
207 / 5 / 2
Регистрация: 27.04.2024
Сообщений: 72
07.05.2024, 12:25  [ТС]
semen1984, Благодарю за ответ, всё верно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.05.2024, 12:25
Помогаю со студенческими работами здесь

Ханойские башни
Головоломка “Ханойские башни” состоит из трех стержней, пронумерованных числами 1, 2, 3. На стержень 1 надета пирамидка из n дисков...

Ханойские башни
# -*- coding: utf-8 -*- import sys n = int(sys.argv) if sys.argv == "-v": f = 1 else: f = 0 class Hanoi:

Зацикленные Ханойские башни
def hanoi(n, x, y): if n > 0: if x % 3 + 2 == 0: hanoi(n - 1, x, y) print(n, x, x % 3 + 1) ...

Рекурсия, одна из задач на ханойские башни
На дорогах Ханоя было введено одностороннее круговое движение, поэтому теперь диск со стержня 1 можно перекладывать только на стержень 2,...

Определить число ходов в головоломке «Ханойские башни»
Ограничение по времени работы программы: 1 секунда Дано число n. Какое наименьшее число перекладываний дисков в головоломке «Ханойские...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru