Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/48: Рейтинг темы: голосов - 48, средняя оценка - 4.96
0 / 0 / 0
Регистрация: 19.05.2010
Сообщений: 45

Ханойская башня

01.06.2011, 14:50. Показов 9967. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
23. Написать программу, которая печатает последовательность действий (в виде «перенести диск с q на r», где q и r – это А,В или С), решающую указанную задачу для n дисков, где n- заданное натуральное число. (При правильном переносе n дисков с А на С обязательно встретится конфигурация, показанная на рис.6,б).
Программу надо составить при помощи функции!
Миниатюры
Ханойская башня  
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.06.2011, 14:50
Ответы с готовыми решениями:

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

Ханойская башня
Здравтвуйте! Нужно решить задачу где на вход дано Н стержней и К дисков и еще известны начальная и конечная конфигурации(где какие диски...

Ханойская башня
Здравствуйте! Скажите пожалуйста как можно реализовать решение для ханойской башни, где я ввожу количество колец и столбиков? Суть я...

4
Freelance
Эксперт С++
 Аватар для asics
2891 / 1826 / 356
Регистрация: 09.09.2010
Сообщений: 3,841
01.06.2011, 15:04
http://www.youtube.com/watch?v=bwxEcpmtHA4
0
 Аватар для BUMER
157 / 12 / 0
Регистрация: 01.04.2009
Сообщений: 103
01.06.2011, 15:15
Реализуется через структуры и списки. Рекурсивная функция присутствует.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
#include <conio.h>
#include <stdio.h>
 
struct usel
{
    int key;
    usel *next;
};
struct sp
{
    usel *head;
    int n;
    void push(int k)
    {
        usel *p;
        p=new usel;
        p->key=k;
        p->next=head->next;
        head->next=p;
        n++;
    }
    int pop()
    {
        usel *p; int k;
        if(empty()) return -1;
        p=head->next;
        head->next=p->next;
        k=p->key;
        delete p;
        n--;
        return k;
    }
    bool empty()
    {
        if(head->next) return false;
        return true;
    }
    void print()
    {
        usel *p;
        if(head->next)
        {
            p=head->next;
            while(p->next)
            {
                printf("%d ", p->key);
                p=p->next;
            }
            printf("%d ", p->key);
        }
    }
    sp()            //конструктор
    {
        head=new usel;
        head->next=0;
        n=0;
    } 
};
 
void vyvod_bashni(sp *tower)            //на каждом шаге выводит состояние всех башен
{
    int i;
    for(i=0;i<3;i++)
    {
        printf("%d bashnja: ", i+1);
        tower[i].print();
        printf("\n");
    }
    printf("\n");
}
 
void hanoy(sp *tower, int n, int from, int to, int help)
{
    int i;
    if(n==1) tower[to].push(tower[from].pop());
    else
    {
        hanoy(tower,n-1,from,help,to);
        vyvod_bashni(tower);
        hanoy(tower,1,from,to,help);
        vyvod_bashni(tower);
        hanoy(tower,n-1,help,to,from);
    }
}
 
void main()
{
    sp tower[3]; int i, a, j, n;
    printf("Vvedite vysotu bashen: "); scanf("%d", &n);
    printf("Vvedite elementy I bashni: ");
    for(j=0;j<n;j++)
    {
        scanf("%d", &a);
        tower[0].push(a);
    }
    printf("\n");
    vyvod_bashni(tower);
    hanoy(tower,n,0,2,1);
    vyvod_bashni(tower);
    getch();
}
2
Higher
 Аватар для diagon
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
01.06.2011, 15:26
Лучший ответ Сообщение было отмечено как решение

Решение

Зачем так извращаться... Можно сделать проще
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
#include <iostream>
void Hanoi(int n, char from, char to, char temp){ //n - число колец, from - имя стержня-источника, to - имя стержня-приемника, temp - имя временного стержня
  if(n>0){
    Hanoi(n-1, from, temp, to);
    std::cout << from << "->" << to << std::endl;
    Hanoi(n-1, temp, to, from);
  }
}
int main(){ //например
    Hanoi(3,'A','B','C');  
    return 0;
}
//Вывод:
//A->B
//A->C
//B->C
//A->B
//C->A
//C->B
//A->B
А вообще учимся гуглить
6
 Аватар для BUMER
157 / 12 / 0
Регистрация: 01.04.2009
Сообщений: 103
01.06.2011, 15:48
diagon, да я не извращался, просто в прошлом семестре сдавали эту задачу, вот и выложил. Вообще тема у нас была "Реализация списков", поэтому код выглядит так заумно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
01.06.2011, 15:48
Помогаю со студенческими работами здесь

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

Ханойская башня
Все вы видели башню Ханоя(если нет, то есть в гугл :D ) . У вас есть 3 столпа «а», «б» и «с», и вам нужно перенести все диски с одного...

Ханойская башня
Легенда гласит, что, в Великом храме города Бенарас, под собором, отмечающим середину мира, находится бронзовый диск, на котором укреплены...

Ханойская башня. Рекурсия
Здравствуйте. Это одно из решений о ханойской башне. Я не могу понять область действия переменных в шаге рекурсии, когда переменные...

Ханойская башня- тесты
Переместить m дисков с одного из трех стержней на другой, соблюдая: 1) диски можно перемещать с одного стержня на другой только по...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru