Модераторы: bsa
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Рекурсивный вызов метода класса 
:(
    Опции темы
zmaximka
Дата 26.8.2012, 18:33 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 65
Регистрация: 27.5.2006
Где: Украина, Одесса

Репутация: нет
Всего: нет



Есть код для инверсии списка с помощью рекурсии. Поскажите как сделать данную функцию методом класса.

Код

List * reverse(List *e1)
{
        if (e1 == 0) return 0;
        if (e1->next == 0) return e1;
        List * rv = reverse(e1->next);
        e1->next->next = e1;
        e1->next = 0;
        return rv;
}


Хотелось бы что-то в духе

Код

class List
{
        Node *head;

        ...
        void reverse();
}

PM MAIL ICQ   Вверх
bsa
Дата 27.8.2012, 00:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Модератор
Сообщений: 9185
Регистрация: 6.4.2006
Где: Москва, Россия

Репутация: 85
Всего: 196



Почти тоже самое. Но у тебя должно быть два метода reverse. Один void reverse(), а второй Node* reverse(Node *el). Причем второй должен быть приватным. Первый просто вызывает второй с параметром head, а результат присваивает обратно head. Код второго почти полностью повторяет приведенный тобой пример.

Это сообщение отредактировал(а) bsa - 27.8.2012, 00:28
PM   Вверх
zmaximka
Дата 27.8.2012, 13:52 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 65
Регистрация: 27.5.2006
Где: Украина, Одесса

Репутация: нет
Всего: нет



Цитата(bsa @ 27.8.2012,  00:28)
Почти тоже самое. Но у тебя должно быть два метода reverse. Один void reverse(), а второй Node* reverse(Node *el). Причем второй должен быть приватным. Первый просто вызывает второй с параметром head, а результат присваивает обратно head. Код второго почти полностью повторяет приведенный тобой пример.

Спасибо. 
PM MAIL ICQ   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Для новичков"
JackYF
bsa

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0653 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.