Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
18 / 18 / 2
Регистрация: 23.02.2012
Сообщений: 132
1

Множественное наследование

07.12.2018, 08:11. Показов 850. Ответов 7

Author24 — интернет-сервис помощи студентам
Всем привет.
Не могу понять следующий подход.
Объясните немного, дальше я сам разберусь.

Есть класс данных Data.
Есть абстрактный класс Node со свойствами next, prev.
На их основе создан класс DataNode.
Создаю класс List. Но есть условие, в классе List входные, выходные типы могут
быть только Node. И работать внутри функций я могу только с Node.
Но передавать в функции класса List должен тип DataNode.

А теперь вопрос: Как я из класса List, могу работать с данными класса DataNode,
если получаемый тип сделан Node.
При создании кода компилятор не увидит же ничего, что не определено в классе Node.
Значить нужно создать виртуальные функции работы с данными. Но ведь класс Node
не знает о классе Data. Как это реализуется?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.12.2018, 08:11
Ответы с готовыми решениями:

Множественное наследование
Добрый вечер! Выполняю дом. работу в плюсах по ООП. Не могу разобраться с реализацией функций. ...

Множественное наследование
7 задание Сделайте пожалуйста, большое спасибо! :good:

Множественное наследование
Здравствуйте! Делаю следующее задание по подготовке к экзамену по С++. Пока только начал....

Множественное наследование
Приветствую всех,хочу сказать сразу, что я не программист и не учусь на него,так-что не пинайте...

7
7 / 7 / 5
Регистрация: 25.03.2018
Сообщений: 377
07.12.2018, 09:42 2
Ну, я предполагаю, что DataNode - производный класс от Node. А Data можно было забацать как union, т.к. это класс данных.
Что-то вроде такого:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Node {
 public: Node *prev, *next;
};
class Data {
 ...
};
class DataNode : public Data {
 private:
       Node DNum;
   ...
}
void main() {
  DataNode *p = &Data;
...}
0
18 / 18 / 2
Регистрация: 23.02.2012
Сообщений: 132
07.12.2018, 09:52  [ТС] 3
Цитата Сообщение от cinekst_207 Посмотреть сообщение
Ну, я предполагаю, что DataNode - производный класс от Node. А Data можно было забацать как union, т.к. это класс данных.
Что-то вроде такого:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
class Node {
 public: Node *prev, *next;
};
class Data {
 ...
};
class DataNode : public Data {
 private:
       Node DNum;
   ...
}
void main() {
  DataNode *p = &Data;
...}
Не совсем.
Тут множественное наследование.
C++
1
class DataNode : public Data, public Node
Я не могу понять, как работать в классе List с классом DataNode, если
по условию задачи я могу использовать только Node:
C++
1
2
3
4
5
6
7
8
9
10
11
12
class List {
private:
   Node * head;
public:
...
   void save(char* fname) {
      Node * node = head;
      while (node) {
         char* str = КАК ТУТ ПРОЧИТАТЬ СТРОКУ ИЗ DataNode???
      }
   }
};
0
166 / 109 / 57
Регистрация: 30.08.2018
Сообщений: 357
07.12.2018, 14:53 4
Нужно текст задачи посмотреть

Наколенный вариант
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
class Node {
 
public:
    Node() : prev(nullptr), next(nullptr) {}
 
    virtual ~Node() {
        std::cout << "Node dtor" << std::endl;
    }
 
    void SetNext(Node *next) {
        this->next = next;
    }
 
    void SetPrev(Node *prev) {
        this->prev = prev;
    }
 
    Node *GetNext() const {
        return next;
    }
 
    Node *GetPrev() const {
        return prev;
    }
 
    virtual void Show() = 0;
 
private:
    Node *prev;
    Node *next;
 
};
 
 
template<class T>
class Data {
    T data;
public:
    void SetData(T data) {
        this->data = data;
    }
 
public:
    T GetData() const {
        return data;
    }
};
 
 
template<class T>
class DataNode : public Node, public Data<T> {
 
public:
    explicit DataNode(T data) {
 
        Data<T>::SetData(data);
    }
 
    void Show() override {
        std::cout << Data<T>::GetData() << " ";
    }
 
};
 
 
template<class T>
class List {
 
public:
 
    List() : head(nullptr) {}
 
    List<T> &operator=(const List<T> &other) = delete;
 
    List<T> &operator=(List<T> &&other) = delete;
 
    ~List() {
        Node *tmp;
        while (head) {
            tmp = head;
            head = head->GetNext();
            delete tmp;
        }
    }
 
 
    void InsertBegin(Node *newNode) {
 
        if (head == nullptr) {
            head = newNode;
        } else {
            newNode->SetNext(head);
            head->SetPrev(newNode);
            head = newNode;
        }
    }
 
    void Display() {
        Node *ptr = head;
        while (ptr) {
            ptr->Show();
            ptr = ptr->GetNext();
        }
    }
 
private:
    Node *head = nullptr;
};
 
int main() {
 
    List<int> int_list;
    for (int i = 0; i < 10; ++i) {
        int_list.InsertBegin(new DataNode(i));
    }
 
    int_list.Display();
 
    std::cout << std::endl;
 
    List<std::string> string_list;
    for (const std::string &s: {"We", "also", "take", "a", "look", "at", "functional"}) {
        string_list.InsertBegin(new DataNode(s));
    }
    string_list.Display();
 
    std::cout << std::endl;
 
}
0
7 / 7 / 5
Регистрация: 25.03.2018
Сообщений: 377
07.12.2018, 14:58 5
Не выйдет такого. Условие корявое(я так считаю), т.к. в первый раз вы сказали, что тип должен быть только Node, а потом пишется, что должен быть DataNode
0
18 / 18 / 2
Регистрация: 23.02.2012
Сообщений: 132
07.12.2018, 15:00  [ТС] 6
Спасибо за подсказку. Дальше я уже сам.
Еще вопрос. Учитывая, что класс Node не знает класс Data и в классе List можно использовать только класс Node. Дружественные функции как использовать? Например переопределение оператора << можно сделать?
0
166 / 109 / 57
Регистрация: 30.08.2018
Сообщений: 357
07.12.2018, 15:19 7
Wurgengel, сделать для всего списка вывод в поток. Для узлов отдельно не делать.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
class List {
 Node *GetHead() const {
        return head;
    }
 
  friend std::ostream &operator<<( std::ostream &output, const List &list ) {
        Node *ptr = list.GetHead();
        while (ptr) {
           ptr->Show();
            ptr = ptr->GetNext();
        }
        return output;
    }
0
18 / 18 / 2
Регистрация: 23.02.2012
Сообщений: 132
07.12.2018, 15:29  [ТС] 8
Спасибо. Вечером попробую написать.
0
07.12.2018, 15:29
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.12.2018, 15:29
Помогаю со студенческими работами здесь

Множественное наследование
Вычислите площадь и периметр прямоугольника, если известны его диагональ и одна из сторон.

множественное наследование
Мечтаю реализовать такую иерархию human-&gt;employee-&gt;doctor в реализации doctor ругает конструктор....

Множественное наследование
Есть два класса Human(fname, lname) и класс Employee c чисто виртуальными функц (зарплата и...

Множественное наследование
Добрый день. У меня имеется базовый класс A. У этого класса есть несколько наследников. Есть еще...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru