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

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> [Borland C++] Двунаправленный список. Опреации с двумерным списком. 
:(
    Опции темы
Melkiy666
Дата 10.4.2007, 21:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 9.1.2007

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



Требуется разработать комплекс функций для обслуживания двунаправленного списка. Необходимо разработать следующие функиции:
1. Создание списка;
2. Вывод значения данных предыдущего элемента;
3. Удаление элемента с заданным значением.
Заранее спасибо!

Это сообщение отредактировал(а) Melkiy666 - 11.4.2007, 06:36
PM MAIL   Вверх
Ryoga
Дата 11.4.2007, 21:55 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 262
Регистрация: 20.9.2005

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



Вопрос то в чём? Вы не знаете, что такое двунаправленный список?
PM MAIL   Вверх
Melkiy666
Дата 11.4.2007, 23:11 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 10
Регистрация: 9.1.2007

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



Как грамотно создать двунаправленный список?
PM MAIL   Вверх
fantast
Дата 11.4.2007, 23:30 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 147
Регистрация: 10.12.2006
Где: минск, столица на шей Родины

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



каждый эллемент этого списка это структура с треия переменными
1. информация (число там или символ какойнить)
2.указатель на следующий элемент списка
3.указатель на предыдущий элемент списка

указатель на предыдущий элемент в первой структуре и указатель на следующий элемент в последней структуре равны нулю

удаление /добавление элементов сводится лишь к динамическому удалению/созданию эллемента структуры, заполнению ее полей и изменение адресов в соседних элементах
--------------------
Эпитафия: Он старался.                                   Неизвестный
PM MAIL   Вверх
Xenon
Дата 12.4.2007, 00:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1529
Регистрация: 12.4.2006

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



Melkiy666, Все можно орагнизовать в класс?


--------------------
user posted image  
PM MAIL   Вверх
Ryoga
Дата 12.4.2007, 13:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 262
Регистрация: 20.9.2005

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



В смысле? Я думаю всё НУЖНО организовать в класс списка.
PM MAIL   Вверх
Xenon
Дата 12.4.2007, 17:26 (ссылка) |    (голосов:3) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
***


Профиль
Группа: Участник Клуба
Сообщений: 1529
Регистрация: 12.4.2006

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



Что-то такое:
Код

#include <iostream>

template <class TYPE>
class key_list
{
private:
    ///////////////////
    struct element
    {
    public:
        TYPE data;
    private:
        template <class TYPE> friend class key_list;
        element* next;
        element* prev;
    };
    /////////////////
    element* m_begin;//Первый элемент списка
    element* m_end;//Последний элемент списка
    int links_count; //Количество элементов в списке
public:
    void display_all() const; //Показать все элементы списка
    void add(const TYPE& data); //Добавить новый элемент
    void remove(const TYPE& var); //Удалить необходимый элемент
    element* cursor (int pos)const; //Итератор

    key_list():m_begin(0),m_end(0),links_count(0){}
    explicit key_list(const key_list<TYPE>& list);
    ~key_list();
};

//////////////////////////////////////
//Показать все элементы
template <class TYPE>
void key_list<TYPE>::display_all() const
{
    if (links_count == 0)
    {
        std::cout << "Nothing to display\n";
        return;
    }
    element* current = m_begin;
    for (int i=0;i<links_count;++i)
    {
        std::cout << i << ") " << current->data << std::endl;
        current = current->next;
    }
}
//////////////////////////////////////
///Добавление нового элемента
template <class TYPE>
void key_list<TYPE>::add(const TYPE& data)
{
    element* link = new element;
    link->data = data;
    if (m_begin == 0)
    {
        m_begin = link;
        m_end = link;
        m_begin->next = link;
        link->prev = 0;
    }
    else
    {
        link->prev = m_end;
        m_end->next = link;
        m_end = link;
    }
    link->next = 0;
    ++links_count;
}
//////////////////////////////////////
///Удаление элемента
template <class TYPE>
void key_list<TYPE>::remove(const TYPE& var)
{
    element* current = m_begin;;
    for (int i = 0; i < links_count && current->data != var; ++i)
    {
        current = current->next;
    }
    if (current == 0) throw "Item doesn`t exists";
    if (current != m_begin && current != m_end) //Если элемент по середине списка
    {
        current->prev->next = current->next;
        current->next->prev = current->prev;
        delete current; //Удаляем необходимый элемент
    }
    else
    {
        if (current == m_begin) //Если это первый элемент ...
        {
            m_begin = current->next;
            current->next->prev = 0;
            delete current;
        }
        else //Если это последний элемент ...
        {
            m_end = current->prev;
            current->prev->next = 0;
            delete current;
        }
    }
    --links_count;
}
//////////////////////////////////////
///Итератор
template <class TYPE>
typename key_list<TYPE>::element* key_list<TYPE>::cursor (int pos)const
{
    if (pos < 0 || pos >= links_count) throw ("Incorrect index - item doesn`t exists\n");
    element* current = m_begin;
    for (int i = 0;i < pos; ++i) current = current->next;
    return current;
}
//////////////////////////////////////
///Копирующий конструктор
template <class TYPE>
key_list<TYPE>::key_list(const key_list<TYPE>& list)
{
    element* new_element = new element;
    //Копируем первый элемент списка
    new_element->data = (list.cursor(0))->data;
    new_element->next = 0;
    m_begin = new_element;
    m_end = new_element;
    //Копируем остальные элементы
    for (int i=1; i<list.links_count; ++i)
    {
        new_element = new element;
        new_element->data = (list.cursor(i))->data;
        m_end->next = new_element;
        m_end = new_element;
    }
    m_end->next = 0;
    links_count = list.links_count;
}
//////////////////////////////////////
///Деструктор
template <class TYPE>
key_list<TYPE>::~key_list()
{
    try
    {
        if (links_count > 0)
        {
            element* current = m_begin;
            while(current->next != 0)
            {
                current = current->next;
                delete current->prev;
            }
            delete m_end;
        }
    }
    catch (...) {}
}

int main()
{
    try
    {
        key_list<int> list;
        list.add(24);
        list.add(142);
        list.add(352);
        list.add(3);
        list.remove(24);
        list.display_all();
    }
    catch (char* msg)
    {
        std::cout << msg;
    }
    return 0;
}


Только я не понял что есть предыдущее значение? Вывести последний элемент списка?..


--------------------
user posted image  
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "Центр помощи"

ВНИМАНИЕ! Прежде чем создавать темы, или писать сообщения в данный раздел, ознакомьтесь, пожалуйста, с Правилами форума и конкретно этого раздела.
Несоблюдение правил может повлечь за собой самые строгие меры от закрытия/удаления темы до бана пользователя!


  • Название темы должно отражать её суть! (Не следует добавлять туда слова "помогите", "срочно" и т.п.)
  • При создании темы, первым делом в квадратных скобках укажите область, из которой исходит вопрос (язык, дисциплина, диплом). Пример: [C++].
  • В названии темы не нужно указывать происхождение задачи (например "школьная задача", "задача из учебника" и т.п.), не нужно указывать ее сложность ("простая задача", "легкий вопрос" и т.п.). Все это можно писать в тексте самой задачи.
  • Если Вы ошиблись при вводе названия темы, отправьте письмо любому из модераторов раздела (через личные сообщения или report).
  • Для подсветки кода пользуйтесь тегами [code][/code] (выделяйте код и нажимаете на кнопку "Код"). Не забывайте выбирать при этом соответствующий язык.
  • Помните: один топик - один вопрос!
  • В данном разделе запрещено поднимать темы, т.е. при отсутствии ответов на Ваш вопрос добавлять новые ответы к теме, тем самым поднимая тему на верх списка.
  • Если вы хотите, чтобы вашу проблему решили при помощи определенного алгоритма, то не забудьте описать его!
  • Если вопрос решён, то воспользуйтесь ссылкой "Пометить как решённый", которая находится под кнопками создания темы или специальным флажком при ответе.

Более подробно с правилами данного раздела Вы можете ознакомится в этой теме.

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

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


 




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


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

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