Форум программистов, компьютерный форум CyberForum.ru

Реализуйте интерфейс динамической структуры list для работы с объектами класса А - C++

Восстановить пароль Регистрация
 
M1kloFFi
0 / 0 / 0
Регистрация: 14.10.2012
Сообщений: 23
23.01.2014, 19:20     Реализуйте интерфейс динамической структуры list для работы с объектами класса А #1
Добрый день товарищи программисты.
Столкнулся с задачей и никак не могу решить...
Так вот вопросы по заданию заключаются в следующем:
1. В правильном ли я направлении, в решении задачи?
2. В каком классе реализовывать конструктор копирования и операцию присваивания, в классе А или В?

Задание:
Кликните здесь для просмотра всего текста
Реализуйте интерфейс динамической структуры list для работы с объектами класса А и дочерними объектами класса А. Напишите реализацию конструктора копирования и операции присваивания.


Мое решение.
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <list>
using namespace std;
 
struct link         // один элемент списка
{
    int data;       // некоторые данные
    link* next;     // указатель на следующую структуру
 
};
///////////////////////////////////////////////////////////
class A
{
private:
    link* first;
    link* last;
public:
    A()            
    { first=last = NULL; }
    void additem(int gh);
    void display();
};
class B:public A
{
public:
    
};
int main()
{
    setlocale(0, "");
    B q;
    
    q.additem(75);
    q.additem(78);
    q.additem(860);
    
    q.display();
    A s=q;
    cout << endl;
    s.display();
    return 0;
 
//////////////////////////
void A::additem ( int d ) // добавление элемента
{
    link* newlink = new link; // выделяем память
    newlink->next=NULL;
    newlink->data=d;
    if(first==NULL) 
    {
        first=newlink;
        last=newlink;}
    else
    {
        last->next=newlink;
        last=newlink;
    }
}
///////////////////////////////////////////////////////////
void A::display()
{
    link* current = first;              // начинаем с первого элемента
    while(current)                      // пока есть данные
    {
        cout << current->data << endl;  // печатаем данные
        current = current->next;        // двигаемся к следующему элементу
    }
}
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.01.2014, 19:20     Реализуйте интерфейс динамической структуры list для работы с объектами класса А
Посмотрите здесь:

Перегрузка арифметических операций для работы с объектами классов. C++
Созданть структуры для сохранения информации динамической матрицы C++
Оптимизация работы метода класса с объектами класса [C++] C++
C++ Написать шаблонный класс List для работы с одноправленными списками в динамической памяти
C++ ООП.Разработать структуру элементов данных класса в виде динамической структуры данных
C++ Выделение динамической памяти для чтения каждой структуры из файла
Есть ли в C++ возможность работы с метаданными класса/структуры? C++
Как написать пуловый аллокатор для работы с объектами C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
monolit
179 / 179 / 21
Регистрация: 24.03.2011
Сообщений: 641
Завершенные тесты: 1
23.01.2014, 20:00     Реализуйте интерфейс динамической структуры list для работы с объектами класса А #2
В правильном, но только ни конструктора копирования, ни оператора присваивания я тут не вижу) Но в целом раз ты смог сделать то, что сделал, то и с другим небе не должно составить труда справиться.

Добавлено через 5 минут
Пардон, немного неправильно прочитал задание...
От тебя требуют следующего:
C++
1
2
3
4
5
6
7
class A {/**/};
class B: public A {/**/};
struct link
{
    A* data;
    link* next;    
}
Если под дочерними понимается наследники, то работать нужно с указателями на объекты (не забывая их, конечно, удалять, когда нужно)
И теперь можно такое сделать (для примера):
C++
1
2
3
4
link l1;
l1.data = new A; //так можно
link l2;
l2.data = new B; //и так тоже
Ну и список для работы с этими link'ами.
Yandex
Объявления
23.01.2014, 20:00     Реализуйте интерфейс динамической структуры list для работы с объектами класса А
Ответ Создать тему
Опции темы

Текущее время: 01:31. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru