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

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

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

Создать класс triangle с полями-сторонами - C++

08.05.2014, 16:57. Просмотров 1061. Ответов 4
Метки нет (Все метки)

Создать класс triangle с полями-сторонами. Определить методы изменения сторон вычисления углов, вычисление периметра. создать производный класс Rightangled (прямоугольный), имеющий поле площади. определить метод вычисления площади

Добавлено через 15 часов 21 минуту
Код для Equiteral(равносторонний)
Помогите доработать его до Rightangled (прямоугольный)
Кликните здесь для просмотра всего текста
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
#include <iostream>
#include <conio.h>
#include <math>
using namespace std;
 
class Triangle{
 public: Triangle(); ~Triangle();
  double  a, b, c;
  double per, alpha, betta, gamma;
  double Sq, rad1, rad2, rad3;
  double gr1, gr2 , gr3;
 
  double  vvod_a()
        {
        cout<<"\nInsert new a: ";
        cin>>a;
        return a;
        }
  double  vvod_b()
        {
         cout<<"\nInsert new b: ";
         cin>>b;
         return b;
        }
  double  vvod_c()
        {
         cout<<"\nInsert new c: ";
         cin>>c;
          if (a+b<c || a+c<b || b+c<a)
           {
           cout<<"Error!!!"<<endl;
           cout<<"Insert new a, b, c: "<<endl;
 
           cin>>a>>b>>c;
            return a,b,c;
           }
         else
           return c;
         }
  double  calculation_perimetr()
        {
        per=a+b+c;
        return per;
        }
 
  double  calculation_a_corner()
        {
        alpha=rad1=acos(((b*b)+c*c-a*a)/(2*c*b));
        gr1=rad1*180/3.14;
        cout<<"\nALPHA size is: \n"<<gr1<<endl<<endl;
        return alpha, gr1, rad1;
        }
  double calculation_b_corner()
        {
        betta=rad2=acos(((a*a)+c*c-b*b)/(2*c*a));
        gr2=rad2*180/3.14;
        cout<<"BETTA size is: \n"<<gr2<<endl<<endl;
         return betta, gr2, rad2;
        }
  double calculation_c_corner()
        {
        gamma=rad3=acos(((b*b)+a*a-c*c)/(2*a*b));
        gr3=rad3*180/3.14;
         cout<<"GAMMA size is: \n"<<gr3<<endl<<endl;
         return gamma, gr3, rad3;
        }
void GET(){cout<<a<<"\n"<<b<<"\n"<<c<<"\n\n\n"<<per<<"\n\n"<<gr1<<"\n"<<gr2<<"\n"<<gr3<<"\n\n";}
};
 
class Equiteral: Triangle {
public:
   Equiteral();
   Equiteral(double x);
  ~Equiteral();
 
  double  change_a()
        {cout<<"\n\nInsert new a: "<<endl;
         cin>>a;
       if (a<0)
           {
           cout<<"Error!!!";
           cout<<"Insert new a: "<<endl;
        cin>>a;
           return a;
            }
         else
         return a;
        }
  double change_b()
        {cout<<"Insert new b: "<<endl;
         cin>>b;
         if (b<0 || b!=a)
           {
            cout<<"Error!!! Chislo b dolzhno ravnyaztsya a!";
            cout<<"Insert new b: "<<endl;
            cin>>b;
           return b;
           }
         else
          return b;
        }
  double change_c()
        {cout<<"Insert new b: "<<endl;
         cin>>c;
        if (c<0 || c!=a || c!=b)
           {
            cout<<"Error!!! Chislo c dolzhno ravnyaztsya a i b!";
            cout<<"Insert new c: "<<endl;
            cin>>c;
            return c;
           }
         else
          return c;
        }
   double  calculation_square()
        {
        Sq=0.5*b*sqrt(b*b-(b/2.0)*(b/2.0));
        return Sq;
        }
 
   double  calculation_a_corner()
        {
        alpha=rad1=acos(((b*b)+c*c-a*a)/(2*c*b));
        gr1=rad1*180/3.14;
        cout<<"\nALPHA size is: \n"<<gr1<<endl<<endl;
        return alpha, gr1, rad1;
        }
  double calculation_b_corner()
        {
        betta=rad2=acos(((a*a)+c*c-b*b)/(2*c*a));
        gr2=rad2*180/3.14;
        cout<<"BETTA size is: \n"<<gr2<<endl<<endl;
         return betta, gr2, rad2;
        }
  double calculation_c_corner()
        {
        gamma=rad3=acos(((b*b)+a*a-c*c)/(2*a*b));
        gr3=rad3*180/3.14;
         cout<<"GAMMA size is: \n"<<gr3<<endl<<endl;
         return gamma, gr3, rad3;
         }
 
void GET(){cout<<a<<"\n"<<b<<"\n"<<c<<"\n\n\n"<<Sq<<"\n\n"<<gr1<<"\n"<<gr2<<"\n"<<gr3<<"\n\n";}
        double x;
};
 
//constructor Triangle
Triangle::Triangle():a(5), b(6), c(7){};
Triangle::~Triangle() {};
 
 
//constructor Equiteral
Equiteral::Equiteral(){};
Equiteral::Equiteral(double x){change_a();change_b();change_c();calculation_a_corner();calculation_b_corner();calculation_c_corner();calculation_square();}
Equiteral::~Equiteral(){};
 
 
 int  main ()
   {
    Triangle TR1;
    TR1.vvod_a();
    TR1.vvod_b();
    TR1.vvod_c();
    TR1.calculation_perimetr();
    TR1.calculation_a_corner();
    TR1.calculation_b_corner();
    TR1.calculation_c_corner();
    TR1.GET();
 
    Equiteral EQ1(1);
    EQ1.GET();
     getch();
     return 0;
   }


Добавлено через 4 часа 57 минут
Актуально
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.05.2014, 16:57     Создать класс triangle с полями-сторонами
Посмотрите здесь:

Создать класс время с полями: час(0-23), минута (0-59), секунда (0-59) C++
C++ Создать класс Triangle для представления треугольника. Поля данных должны включать углы и стороны.
C++ Создать класс с двумя полями и конструктором
Создать класс triangle с полями-сторонами C++
C++ создать класс triangle , содержащий следующие члены класса
Создать класс Цех со следующими полями: название, фамилия начальника, количество работающих C++
C++ Создать класс triangle
Создать класс RIELTER, с полями в закрытой части: количество комнат, этаж; площадь; адрес C++
C++ Создать класс Triangle, содержащий следующие члены класса
C++ Создать класс Triangle, содержащий следующие члены класса
C++ Создать класс матросы с 2 полями
Создать класс Triangle, разработав следующие элементы класса C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Bott1q2
Сообщений: n/a
08.05.2014, 19:29     Создать класс triangle с полями-сторонами #2
Не очень понял зачем столько полей вроде в задании сказано только стороны в общем набросал быстро по твоей аналогии все кроме углов думаю сам доделаешь ну и ошибки пофиксишь тоже если они есть
Вложения
Тип файла: rar Class_tr.rar (1.4 Кб, 49 просмотров)
Slight
0 / 0 / 0
Регистрация: 27.12.2013
Сообщений: 36
08.05.2014, 20:36  [ТС]     Создать класс triangle с полями-сторонами #3
Спасибо, в этом разобрался.
А как будут выглядеть методы изменения сторон?
Slight
0 / 0 / 0
Регистрация: 27.12.2013
Сообщений: 36
08.05.2014, 20:43  [ТС]     Создать класс triangle с полями-сторонами #4
Так с углами - все дела, проверяет если прямоугольный - то считает площадь, если нет, то пишет 0
Помогите с методом изменения сторон
Вложения
Тип файла: rar right11.rar (245.2 Кб, 46 просмотров)
Slight
0 / 0 / 0
Регистрация: 27.12.2013
Сообщений: 36
10.05.2014, 08:01  [ТС]     Создать класс triangle с полями-сторонами #5
актуально

Добавлено через 8 часов 5 минут
+++

Добавлено через 13 часов 32 минуты
Вроде как все написано и работает
Не могу понять одного!
Реализовать методы изменения сторон. То есть? Я же просто могу задать их заново для нового треугольника, или тут что-то другое, например увеличить сторону А на +5, В на -2 и т.д.
Подскажите
Yandex
Объявления
10.05.2014, 08:01     Создать класс triangle с полями-сторонами
Ответ Создать тему
Опции темы

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