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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
M1kloFFi
0 / 0 / 0
Регистрация: 14.10.2012
Сообщений: 27
#1

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

23.01.2014, 19:20. Просмотров 376. Ответов 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;        // двигаемся к следующему элементу
    }
}
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.01.2014, 19:20
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Реализуйте интерфейс динамической структуры list для работы с объектами класса А (C++):

Написать шаблонный класс List для работы с одноправленными списками в динамической памяти - C++
Для объектов класса List определить операции проверки списка на пустоту, добавления элемента в начало списка, в конец списка, подсчет...

Оптимизация работы метода класса с объектами класса [C++] - C++
Здравствуйте! Я хочу сделать 25 000 объектов класса, в последствии они все будут разными, но сейчас, для упрощения задачи, я делаю их...

ООП.Разработать структуру элементов данных класса в виде динамической структуры данных - C++
Здравствуйте, получил задание, но немного недопонимаю как это сделать, с чего начать. Помогите пожалст или объясните образно как сделать, а...

Созданть структуры для сохранения информации динамической матрицы - C++
прошу помочь срочно --&gt; Созданть структуры для сохранения информации динамической матрицы (C++) ...

Перегрузка арифметических операций для работы с объектами классов. - C++
Создать класс Animal, содержащий следующие элементы: - поле «вес» float Mass; - поле «пол» char* Sex; - поле «окрас» char* Color; ...

Как написать пуловый аллокатор для работы с объектами - C++
Здравствуйте! Подскажите как написать пуловый аллокатор для работы с объектами

1
monolit
186 / 185 / 22
Регистрация: 24.03.2011
Сообщений: 669
Завершенные тесты: 1
23.01.2014, 20:00 #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'ами.
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
23.01.2014, 20:00
Привет! Вот еще темы с ответами:

Есть ли в C++ возможность работы с метаданными класса/структуры? - C++
Здравствуйте уважаемые форумчане. Есть ли в с++ возможность работы с метеоданными класса/структуры ?

Выделение динамической памяти для чтения каждой структуры из файла - C++
Здравствуйте! Никак не получается выделить динамическую память под каждую структуру из файла, учитывая, что я не знаю сколько структур в...

Функции для работы с динамической памятью - C++
только начал изучать С++ сразу столкнулся с кучей вопросов. задача такая : разработать функции Create,Resize и Remove для создания,...

Средства для контроля работы с динамической памятью - C++
Здравствуйте, товарищи! При написании программы на С++ встала проблема контроля выделения/удаления динамической памяти (необходимо для...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru