Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.65/17: Рейтинг темы: голосов - 17, средняя оценка - 4.65
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
1

Массивы объектов. Наследование

14.06.2011, 18:43. Просмотров 3074. Ответов 26
Метки нет (Все метки)

Здравствуйте! Скоро экзамен, а я никак не могу решить эту задачу, может кто-то поможет?
Вот условие:
Создать класс окружность, член класса - R. Предусмотреть в классе методы вычисления и вывода сведений о фигуре – площади, длины окружности. Создать производный класс – конус с высотой h, добавить в класс метод определения объема фигуры, перегрузить методы расчета площади и вывода сведений о фигуре. Написать программу, демонстрирующую работу с классом: дано N окружностей и M конусов, найти количество окружностей, у которых площадь меньше средней площади всех окружностей, и наибольший по объему конус.
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.06.2011, 18:43
Ответы с готовыми решениями:

Массивы объектов класса + наследование
Здравствуйте! Пробелмка такая! есть массив обьектов класса CList и наследник...

Программирование на С++ с использованием классов. Массивы объектов. Наследование
Помогите с программированием,пожалуйста!!!!!!!!!!!! Создать класс...

Программирование на С++ с использованием классов. Массивы объектов. Наследование
Создать класс окружность, член класса - R. Предусмотреть в классе методы...

Наследование,порождение объектов
Помогите,пожалуйста.Задача состоит в том,что даны...

Задача на связность объектов и наследование
Добрый вечер. Помогите с задачей. Нужно написать классы Товар - Категория -...

26
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
14.06.2011, 18:50 2
собственно в чём проблема?
1
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
14.06.2011, 18:53  [ТС] 3
pito211, проблема в мозгах. Я наследование плохо шарю, В целом кое-что получилось но никак не могу рассчитать количество окружностей, у которых площадь меньше средней площади всех окружностей
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
14.06.2011, 18:57 4
конус надо унаследовать от окружности и добавить поле высоты. В задании же так и сказано, не знаю как ещё подробнее разжевать. Площадь переопределить как сумму основания и боковую. Сумму основания счиать не надо, можно просто метод базового класса вызвать, у тебя же там есть такая функция
1
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
14.06.2011, 19:01  [ТС] 5
pito211, ээх как жалко, что я не учил наследование.(( А можно у вас купить решение этой задачи?
0
silent_1991
14.06.2011, 19:07
  #6

Не по теме:

pito211, я бы на вашем месте не продал. Ведь это так прекрасно - ты и только ты умеешь наследовать конусы от окружностей, машины от колёс и здания от фундаментов :D

4
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
14.06.2011, 19:08 7
ладно возьмусь, за символический стольник. Отпишусь как будет готово
1
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
14.06.2011, 20:19  [ТС] 8
ок, вот моя ася если что 598681семь87 думаю там проще будет общаться. Спасибо!

Добавлено через 1 час 9 минут
pito211, а к вечеру будет готово? Просто завтра у меня уже экзамен))
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
14.06.2011, 21:25 9
да уже написано, сейчас посмотрю ещё
1
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
14.06.2011, 21:36  [ТС] 10
pito211, отлично! Вот сюда можете отправить номер своего кошелька uchilok.net@yandex.ru, потом и саму задачу туда же!

А вот, кому интересно, что получилось у меня!

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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
#include <iostream>
#include <math.h>
#include <conio.h>
using namespace std;
 
class Circle
{
public:
    Circle();
    Circle(double);
 
    void set_r(double);
    double get_r() const;
 
    double area() const;
    double circuit() const;
 
    void print_area() const;
    void print_circuit() const;
 
private:
    double _r;
 
    static const double Pi;
};
 
const double Circle::Pi = 3.14;
 
Circle::Circle():
 
_r(1)
{
}
 
Circle::Circle(double r):
 
_r(r)
{
}
 
void Circle::set_r(double r)
{
    _r = r;
}
 
double Circle::get_r() const
{
    return _r;
}
 
double Circle::area() const
{
    return Pi * _r * _r;
}
 
double Circle::circuit() const
{
    return 2 * Pi * _r;
}
 
void Circle::print_area() const
{
    std::cout << area();
}
 
void Circle::print_circuit() const
{
    std::cout << circuit();
}
 
//-----------------------------------------------------------------------------
 
class Konus: public Circle
{
public:
    Konus();
    Konus(double, double);
 
    void set_h(double);
    double get_h() const;
 
    double area() const;
    double volume() const;
 
    void print_area() const;
    void print_volume() const;
 
private:
    double _h;
};
 
Konus::Konus():
Circle(),
_h(1)
{
}
 
Konus::Konus(double r, double h):
Circle(r),
_h(h)
{
}
 
void Konus::set_h(double h)
{
    _h = h;
}
 
double Konus::get_h() const
{
    return _h;
}
 
double Konus::area() const
{
    return Circle::circuit() * (get_r() + _h);
}
 
double Konus::volume() const
{
    return Circle::area() * _h*2;
}
 
void Konus::print_area() const
{
    std::cout << area();
}
 
void Konus::print_volume() const
{
    std::cout << volume();
}
 
//-----------------------------------------------------------------------------
 
int main(){
int N,M;
    cout<<"Vvedite kolichestvo okrujnostei (N) i konusov (M): "<<endl;
    cout<<"N="; cin>>N; cout<<"M="; cin>>M;
{
    Circle circle_arr[N];
    Konus konus_arr[M];
 
    double avg_circle_circuit = 0;
    double max_konus_volume;
    std::cout << "Circles:" << std::endl;
 
    for (int i = 0; i < N; ++i)
    {
        double r;
 
 
        std::cout << "Enter r [" << i << "]: ";
        std::cin >> r;
 
        circle_arr[i].set_r(r);
 
                circle_arr[i].set_r(r);
        circle_arr[i].set_r(r);
 
        avg_circle_circuit += circle_arr[i].area();
    }
 
    avg_circle_circuit /= N;
 
    std::cout << std::endl;
 
 
    std::cout << "Konus:" << std::endl;
 
    for (int i = 0; i < M; ++i)
    {
        double r;
        double h;
 
 
        std::cout << "Enter r [" << i << "]: ";
        std::cin >> r;
        std::cout << "Enter h [" << i << "]: ";
        std::cin >> h;
 
        konus_arr[i].set_r(r);
        konus_arr[i].set_h(h);
 
if (i == 0)
            max_konus_volume = konus_arr[0].volume();
        else
      {
            double volume = konus_arr[i].volume();
 
            if (max_konus_volume < volume)
              max_konus_volume = volume;
     }
   }
 
 
    std::cout << std::endl;
 
    std::cout << "Avg circle area: " << avg_circle_circuit <<std::endl;
    std::cout << "Max konus volume: " << max_konus_volume << std::endl;
 
    return 0;
}}
Только высчитывает площадь средней окружности, а не кол-во площадей окружностей меньше средних, макс. объём конуса чёт тоже не хочет, где-то напортачил((
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
14.06.2011, 22:01 11
вот экзешник. Проект написан в Visual Studio 2008, спецификации полностью соответсвует. Исходники после оплаты, стольник как договаривались на мобилку 8-913-619-58-74 можно в любом автомате положить. (Звонить во время своих экзаменов спрашивать чё-то, просить доделать\переделать и прочие вопросы не надо)
1
Вложения
Тип файла: rar New Архив WinRAR.rar (18.8 Кб, 25 просмотров)
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
14.06.2011, 22:15 12
в код блоксе не знаю как там, короче можешь создать проект с такими же файлами и закопипасть мои файлы туда
1
Вложения
Тип файла: zip New Архив ZIP - WinRAR.zip (1.50 Мб, 29 просмотров)
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
14.06.2011, 22:45  [ТС] 13
Ээх чёт под коде блокс не работатет(((

pito211, не мог бы адаптировать свою задачу под коде блокс? А то завтра экзамен и вот с последней задачей такие проблемы!

Или попинайте кто-нить моё решение:
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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
#include <iostream>
#include <math.h>
#include <conio.h>
using namespace std;
 
class Circle
{
public:
    Circle();
    Circle(double);
 
    void set_r(double);
    double get_r() const;
 
    double area() const;
    double circuit() const;
 
    void print_area() const;
    void print_circuit() const;
 
private:
    double _r;
 
    static const double Pi;
};
 
const double Circle::Pi = 3.14;
 
Circle::Circle():
 
_r(1)
{
}
 
Circle::Circle(double r):
 
_r(r)
{
}
 
void Circle::set_r(double r)
{
    _r = r;
}
 
double Circle::get_r() const
{
    return _r;
}
 
double Circle::area() const
{
    return Pi * _r * _r;
}
 
double Circle::circuit() const
{
    return 2 * Pi * _r;
}
 
void Circle::print_area() const
{
    std::cout << area();
}
 
void Circle::print_circuit() const
{
    std::cout << circuit();
}
 
//-----------------------------------------------------------------------------
 
class Konus: public Circle
{
public:
    Konus();
    Konus(double, double);
 
    void set_h(double);
    double get_h() const;
 
    double area() const;
    double volume() const;
 
    void print_area() const;
    void print_volume() const;
 
private:
    double _h;
};
 
Konus::Konus():
Circle(),
_h(1)
{
}
 
Konus::Konus(double r, double h):
Circle(r),
_h(h)
{
}
 
void Konus::set_h(double h)
{
    _h = h;
}
 
double Konus::get_h() const
{
    return _h;
}
 
double Konus::area() const
{
    return Circle::circuit() * (get_r() + _h);
}
 
double Konus::volume() const
{
    return Circle::area() * _h*2;
}
 
void Konus::print_area() const
{
    std::cout << area();
}
 
void Konus::print_volume() const
{
    std::cout << volume();
}
 
//-----------------------------------------------------------------------------
 
int main(){
int N,M;
        cout<<"Vvedite kolichestvo okrujnostei (N) i konusov (M): "<<endl;
        cout<<"N="; cin>>N; cout<<"M="; cin>>M;
{
    Circle circle_arr[N];
    Konus konus_arr[M];
 
    double avg_circle_circuit = 0;
    double max_konus_volume;
    std::cout << "Circles:" << std::endl;
 
    for (int i = 0; i < N; ++i)
    {
        double r;
 
 
        std::cout << "Enter r [" << i << "]: ";
        std::cin >> r;
 
        circle_arr[i].set_r(r);
 
                circle_arr[i].set_r(r);
        circle_arr[i].set_r(r);
 
        avg_circle_circuit += circle_arr[i].area();
    }
 
    avg_circle_circuit /= N;
 
    std::cout << std::endl;
 
 
    std::cout << "Konus:" << std::endl;
 
    for (int i = 0; i < M; ++i)
    {
        double r;
        double h;
 
 
        std::cout << "Enter r [" << i << "]: ";
        std::cin >> r;
        std::cout << "Enter h [" << i << "]: ";
        std::cin >> h;
 
        konus_arr[i].set_r(r);
        konus_arr[i].set_h(h);
 
if (i == 0)
            max_konus_volume = konus_arr[0].volume();
        else
      {
            double volume = konus_arr[i].volume();
 
            if (max_konus_volume < volume)
              max_konus_volume = volume;
     }
   }
 
 
    std::cout << std::endl;
 
    std::cout << "Avg circle area: " << avg_circle_circuit <<std::endl;
    std::cout << "Max konus volume: " << max_konus_volume << std::endl;
 
    return 0;
}}
Нужно вывести количество площадей, которые меньше средних (пока выводит просто среднюю площадь);
Нужно вывести макс. объём конуса (пока выводит какуюта хрень);
Спасибо всем откликнувшимся!
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
15.06.2011, 06:01 14
должно работать, "StdAfx" и "targetever" файлы в блоксе создавать не надо

Добавлено через 17 минут
какие ошибки хоть пишет?
1
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
15.06.2011, 09:31  [ТС] 15
pito211, помоги, пожалуйста, через 4 часа экзамен. Нет загрузочного файла cbp который бы мог открыть все остальные файлы. Ошибок много 34шт. все такого плана:
C++
1
2
3
4
5
6
G:\project4Sale\project4Sale\project4Sale.o:project4Sale.cpp|| undefined reference to `geometry::Cone::Cone(double const&, double const&)'|
G:\project4Sale\project4Sale\project4Sale.o:project4Sale.cpp|| undefined reference to `geometry::Cone::v() const'|
G:\project4Sale\project4Sale\project4Sale.o:project4Sale.cpp|| undefined reference to `geometry::Cone::v() const'|
G:\project4Sale\project4Sale\project4Sale.o:project4Sale.cpp|| undefined reference to `geometry::Cone::operator=(geometry::Cone const&)'|
G:\project4Sale\project4Sale\project4Sale.o:project4Sale.cpp|| undefined reference to `geometry::Cone::~Cone()'|
G:\project4Sale\project4Sale\project4Sale.o:project4Sale.cpp||
Добавлено через 2 минуты
как мне связать все файлы?

Добавлено через 25 минут
Создал новый проект. Объединил все файлы. Выдаёт 1 ошибку
C++
1
\C++\project4Sale\main.cpp|44|error: '_TCHAR' has not been declared|
Где только я её не объявлял и как локальную и как глобальную всё равно эта ошибка. А какой хоть тип должна иметь _TCHAR? Вот сама программа:
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
// project4Sale.cpp: определяет точку входа для консольного приложения.
//
 
#include <vector>
#include <iostream>
 
 
#include "circle.h"
#include "cone.h"
 
using namespace std;
using geometry::Circle;
using geometry::Cone;
 
 
Cone max_v(const vector<Cone> &cones)
{
    Cone max_tmp(0, 0);
    for (vector<Cone>::const_iterator it = cones.begin(); it != cones.end(); it++)
    {
        double tmp = max_tmp.v();
        double tmp2 = it->v();
        if ( tmp2 > tmp )
        {
            max_tmp = *it;
        }
    }
 
    return max_tmp;
}
 
double average_s(const vector<Circle> &circles)
{
    double tmp = 0;
 
    for (vector<Circle>::const_iterator it = circles.begin(); it != circles.end(); it++)
    {
        tmp += it->s();
    }
 
    return ( tmp / circles.size() );
}
 
int _tmain(int argc, _TCHAR* argv[])
{
    size_t              N,  //Circles
                        M;  //Conuses
 
    vector<Circle>      circles;
    vector<Cone>        cones;
 
 
    /////////////////////////////////
    //Big part of code with circles//
    /////////////////////////////////
 
 
    cout    << "Hello!" << endl
            << "Input number of circles n = " << endl;
    cin     >> N;
 
    cout    << "Input radiuses" << endl;
 
    for (size_t i = 0; i != N; i++)
    {
        static int  radius;
 
        cout << i + 1 << "> ";
        cin >> radius;
        circles.push_back(Circle(radius));
    }
 
 
 
    double avr_s = average_s(circles);
    size_t circle_less      = 0; //Количество окружностей, у которых площадь меньше средней площади
    size_t circle_greater   = 0; //Количество окружностей, у которых площадь больше средней площади
 
    for (vector<Circle>::const_iterator it = circles.begin(); it != circles.end(); it++)
    {
        if (it->s() <= avr_s)
        {
            circle_less++;
        }
        else
        {
            circle_greater++;
        }
    }
 
    cout << "Number of circles, which area are greater is " << circle_greater << endl;
    cout << "Number of circles, which area are less or equal is " << circle_less << endl;
 
 
    ///////////////////////////////
    //Big part of code with cones//
    ///////////////////////////////
 
    cout    << "Hello!" << endl
            << "Input number of cones m = " << endl;
    cin     >> M;
 
 
    for (size_t i = 0; i != M; i++)
    {
        double  radius;
        double  height;
 
        cout    << i + 1 << "> " << endl
                << "Radius: ";
        cin >> radius;
        cout    << "Height: ";
        cin >> height;
 
        cones.push_back(Cone(radius, height));
        cout << endl;
    }
 
    Cone the_biggest_cone = max_v(cones);
 
    cout    << "This is the cone with the largest volume:"  << endl;
 
 
    the_biggest_cone.print();
 
    return 0;
}
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
15.06.2011, 09:41 16
просто измени на main, это же какой-то майкрософтовский define вроде wmain, а TCHAR на char или вообще аргументы сотри они здесь не нужны
1
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
15.06.2011, 09:55  [ТС] 17
Готово, новая ошибка
C++
1
 \C++\project4Sale\circle.h|11|error: expected unqualified-id before numeric constant|
Сама строчка с ошибкой:
const double M_PI = 3.14;
А тут что исправить?
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
15.06.2011, 10:03 18
M_PI видимо где-то у тебя в math.h определено, хотя никакого пересечения быть не должно. Я же в отдельный namespace его вынес. Короче M_PI переименуй
0
MisterXXl
0 / 0 / 0
Регистрация: 18.01.2011
Сообщений: 15
15.06.2011, 10:14  [ТС] 19
pito211, ты имеешь ввиду переименовать, например, в K_PI = 3.14? Я так сделал выдал новую ошибку:
\C++\project4Sale\main.cpp|71|error: call of overloaded 'Circle(int&)' is ambiguous|
ээх наверно мне не исправить эту задачу((( Твоё решение хоть грамотное, оформлено правильно, но я не всё в нём понимаю и исправить ошибки не смогу. Можешь посмотреть на моё решение, которое я указал в 13 посте, и указать на ошибки, и сказать как их исправить?
0
pito211
186 / 173 / 18
Регистрация: 22.03.2010
Сообщений: 612
15.06.2011, 10:32 20
цикл выглядит нормально, только формула объёма у конуса не такая

Добавлено через 7 минут
скажи преподу, что писал в VS, хрен с ним что не компилится, главное код. А он вроде бы нормально структурирован и предельно ясен, это уже причуды g++, попробуй вынести эту константу в глобальную область, не знаю короче чё ещё предложить
0
15.06.2011, 10:32
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
15.06.2011, 10:32

Массивы и наследование
Мальчики, помогите, пожалуйста!!! Реализовать класс Money для работы с...

Наследование static атрибута(хранение количества объектов наследуемых классов)
Есть абстрактный класс base, от него наследуются 3 класса child1 child2 child3....

Наследование класса. Массивы и их суммирование
Мне нужно создать класc Set в котором реализовать 2 метода setSet и getSet на...


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

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

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