Форум программистов
 

Восстановите пароль или Зарегистрируйтесь на форуме, о проблемах и с заказом рекламы пишите сюда - alarforum@yandex.ru, проверяйте папку спам!

Вернуться   Форум программистов > IT форум > Помощь студентам
Регистрация

Восстановить пароль
Повторная активизация e-mail

Купить рекламу на форуме - 42 тыс руб за месяц

Ответ
 
Опции темы Поиск в этой теме
Старый 17.02.2014, 01:54   #1
the_faceless
Пользователь
 
Регистрация: 02.12.2012
Сообщений: 15
По умолчанию С++. Создать базовый класс список. Реализовать на базе списка стек и очередь... Объяснить программу (написать комментарии)

Здравствуйте, помогите пожалуйста разобраться что как работает в программе (напишите комментарии).
Задание: Создать базовый класс список. Реализовать на базе списка стек и очередь с виртуальными функциями вставки и вытаскивания
Вот программа, объясните пожалуйста что к чему, спасибо
Код:
#include "stdafx.h"
#include <iostream>
using namespace std;
 
//параметризованный однонаправленный список
template <typename T>
class List
{
 
private:
    //----single list node
    class node
    {
    public:
        T data;
 
        node*   next;
    public:
        node(node *_next)
            :next(_next)
        {}
    };
 
private:
    class node  *head, *tail;
 
public:
    void push_front(const T& val)
    {
        if (empty())
        {
            head = new node(tail);
            head->data = val;
        }
        else
        {
            head = new node(head);
            head->data = val;
        }
    }
 
public:
    void push_back(const T& val)
    {
        if (empty())
        {
            head = new node(tail);
            head->data = val;
        }
        else
        {
            node *srh_node = head;
            for (;srh_node->next != tail ; srh_node = srh_node->next)
                ;
 
 
            srh_node->next = new node(tail);
            srh_node->next->data = val;
        }
    }
 
public:
    T pop_front()
    {
        T val = head->data;
        node    *to_del = head;
        head = head->next;
 
        delete to_del;
        return val;
    }
 
public:
    T pop_back()
    {
        node *srh_node = head;
 
        if (srh_node->next == tail)
        {
            head = tail;
            T val = srh_node->data;
            delete srh_node;
 
            return val;
        }
        else
        {
            for (; (srh_node->next->next != tail); srh_node = srh_node->next)
                ;
 
            T val = srh_node->next->data;
            node* to_del = srh_node->next;
            srh_node->next = srh_node->next->next;
            delete to_del;
 
            return val;
        }
    }
 
public:
    bool empty() const
    {
        return head == tail;
    }
 
public:
    virtual void clear()
    {
        node *dl_node;
        for (node *cr_node = head; cr_node != tail;)
        {
            dl_node = cr_node;
            cr_node = cr_node->next;
 
            delete dl_node;
        }
 
        head = tail;
    }
 
public:
    List()
    {
        head = tail = new node(0);
    }
 
public:
    List(const List& l)
    {
        clear();
        node *cur_node = head;
 
        for (node* srh_node = l.head;
            srh_node != l.tail; srh_node = shr_node->next)
        {
            cur_node->next = new node(tail);
            cur_node->data = srh_node->data;
        }
 
    }
 
public:
    virtual ~List()
    {
        clear();
    }
};
 
template <typename Ty>
class Queue : protected List<Ty>
{
public:
    Queue()
        :List()
    {}
 
public:
    Queue(const Queue& rhs)
        :List(rhs)
    {}
 
public:
    ~Queue()
    {}
 
public:
    inline void push(const Ty& value)
    {
        List<Ty>::push_back(value);
    }
 
public:
    inline Ty pop()
    {
        return List<Ty>::pop_front();
    }
};
 
template <typename Ty>
class Stack : protected List<Ty>
{
public:
    Stack()
        :List()
    {}
 
public:
    Stack(const Stack& rhs)
        :List(rhs)
    {}
 
public:
    ~Stack()
    {}
 
public:
    inline void push(const Ty& value)
    {
        List<Ty>::push_front(value);
    }
 
public:
    inline Ty pop()
    {
        return List<Ty>::pop_front();
    }
};
 
int main()
{
    Queue<int> qi;
    qi.push(1);    qi.push(2);    qi.push(3);
 
    cout << qi.pop() << endl;
    cout << qi.pop() << endl;
    cout << qi.pop() << endl;
 
    Stack<int> si;
    si.push(1);    si.push(2);    si.push(3);
 
    cout << si.pop() << endl;
    cout << si.pop() << endl;
    cout << si.pop() << endl;
    system("pause");
}
the_faceless вне форума Ответить с цитированием
Ответ


Купить рекламу на форуме - 42 тыс руб за месяц



Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
C++ Создать базовый класс список the_faceless Помощь студентам 1 17.02.2014 10:02
Создать абстрактный базовый класс C++ MicRaiS Общие вопросы C/C++ 3 11.06.2012 13:14
Правильна ли такая реализация списка из указателей на базовый класс? Archet Общие вопросы C/C++ 14 18.01.2012 16:08
Чем отличается Очередь на базе списка от Очереди на базе массива? TwiX Общие вопросы C/C++ 7 16.02.2011 12:17
Создать базовый класс sT1mfy Общие вопросы Delphi 3 11.06.2010 21:38