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

C++

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

Динамическая списочная структура, содержащая объекты классов, связанных наследованием - C++

28.10.2015, 17:34. Просмотров 283. Ответов 3

В общем. Есть базовый класс и 2 класса наследника. Нужно создать динамическую структуру(пусть это будет односвязный список) в который можно добавлять или удалять объекты любого из 3-х классов.
Я сделал односвязный список в который можно добавлять базовый класс. Но вот как реализовать возможность хранения в одном списке различных классов?

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
#include <stdio.h>
#include <iostream>
#include <cstdlib>//РусскийЯзык
//Вот эти 3 класса
#include "ClassDrob.h"//Основной класс рациональных дробей
#include "DrobResult.h"//Класс дроби с результатом
#include "MixedDrob.h"//Класс смешанной дроби
 
struct spisok{
    drob A;
    spisok *next;
    //spisok(){};
};
 
using namespace std;
void main(){
    setlocale(LC_ALL, "rus");
    
    spisok *dano = NULL;//указатель на начало списка
    spisok *x;//вспомогательный указатель на конец списка
 
    x = dano;
    
 
 
    for (int i = 0; i < 3; i++){
        if (i != 0) {
            x->next = new spisok;
            x = x->next;
        }
        if (i == 0) { x = new spisok; dano = x; }
        cin >> x->A;
        x->next = NULL;
    }
 
    x = dano;
    while (x != NULL){
        cout << x->A << " ";
        x = x->next;
    }
    
    system("pause");
}
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.10.2015, 17:34     Динамическая списочная структура, содержащая объекты классов, связанных наследованием
Посмотрите здесь:

Сформировать набор классов связанных между собой виртуальным наследованием,описать каждый класс - C++
Сформировать набор классов связанных между собой виртуальным наследованием,описать каждый класс

Массив классов с наследованием - C++
Hi,all and thanks in advance. Shape base class, line and Point derived classes. What should I declare in .h files and implement in .cpp...

Проблемы с наследованием классов - C++
1-е задание: Создать класс базовый класс «вещественное число». Элементы класса (поля имеют статус доступа protected): поле,...

помогите решить задачу с массовым наследованием классов - C++
Общая постановка. Создать программу с абстрактным базовым классом и множественным наследованием, реализовать в нем: • конструктор, ...

Слово return в простом примере с наследованием классов - C++
Добрый день! Ниже приведён код. Подскажите, пожалуйста, для чего тут return . Почему нельзя просто вставить ++ count (или --count)?...

Оформление связанных классов - C++ Builder
В общем есть у меня 2 класса: class Tower{ public: Bullet* bullet; int dmg; double attackSpeed; Tower(){}

После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Opuzer
0 / 0 / 1
Регистрация: 27.03.2014
Сообщений: 12
30.10.2015, 06:39  [ТС]     Динамическая списочная структура, содержащая объекты классов, связанных наследованием #2
А все, спасибо, разобрался.
SatanaXIII
Супер-модератор
Эксперт С++
5602 / 2636 / 242
Регистрация: 01.11.2011
Сообщений: 6,495
Завершенные тесты: 1
30.10.2015, 11:07     Динамическая списочная структура, содержащая объекты классов, связанных наследованием #3
Цитата Сообщение от Opuzer Посмотреть сообщение
А все, спасибо, разобрался.
Было б очень хорошо, если б вы поделились сведениями о том. как вы разобрались.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
30.10.2015, 14:39     Динамическая списочная структура, содержащая объекты классов, связанных наследованием
Еще ссылки по теме:

Динамическая память. Функции. Массивы .Объекты - C++
Всем привет. Возник следующий вопрос: 1.Когда в c++ из функции возвращается объект (экземпляр какого-то класса), то насколько мне...

Динамическая структура - C++
Помогите пожалуйста с заданием. Дано задание: На междугородной телефонной станции картотека абонентов, содержащая сведения о телефонах и...

Динамическая структура - C++
Добрый день. Хочу создать примерно такую структуру: struct person { char name, char delimeter, char age, char delimeter, ... ...

Динамическая структура - C++
Составить программу, которая содержит динамическую информацию о наличии автобусов в автобусном парке. Сведения о каждом автобусе...

динамическая структура... - Visual C++
привет.....есть очередь и лист....до конца очереди ...надо добавить елементи листа между минимальним и максимальним...но невключая их...или...

Динамическая структура данных - C++
Нужна помощь с динамическими структурами данных: Написать программу, которая сохраняет элементы с помощью динамической структуры...


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

Или воспользуйтесь поиском по форуму:
Opuzer
0 / 0 / 1
Регистрация: 27.03.2014
Сообщений: 12
30.10.2015, 14:39  [ТС]     Динамическая списочная структура, содержащая объекты классов, связанных наследованием #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
#include <stdio.h>
#include <iostream>
#include <cstdlib>//РусскийЯзык
#include "ClassDrob.h"//Основной класс рациональных дробей
#include "DrobResult.h"//Класс дроби с результатом
#include "MixedDrob.h"//Класс смешанной дроби
 
struct spisok{
    drob *A;//указатель на базовый класс
    spisok *next;
};
 
using namespace std;
void main(){
    setlocale(LC_ALL, "rus");
    
    spisok *dano = NULL;//указатель на начало списка
    spisok *x;//вспомогательный указатель на конец списка
 
    x = dano;
    drob n1(1, 3);
    
    MixedDrob n2(7, 3);
 
 
 
    for (int i = 0; i < 3; i++){
        if (i != 0) {
            x->next = new spisok;
            x = x->next;
        }
        if (i == 0) { x = new spisok; dano = x; }
        (x->A)=&n2;
        //(x->A).getResult();
        x->next = NULL;
    }
 
    x = dano;
    while (x != NULL){
        //cout << *(x->A) << " ";
        (*(x->A)).getDrob();
 
        x = x->next;
    }
 
 
    
    system("pause");
}
Yandex
Объявления
30.10.2015, 14:39     Динамическая списочная структура, содержащая объекты классов, связанных наследованием
Ответ Создать тему
Опции темы

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