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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Создать динамический список для структуры http://www.cyberforum.ru/cpp-beginners/thread1169503.html
Здраствуйте! Очень нужна Ваша помощь... Нужно создать динамический список для структуры. В списке должны быть реализованы следующие функции: создание списка, просмотр списка, удаление списка, вывод на экран, поиск, редактирование записи, удаление записи, добавление новой записи, создание записи, вывод на экран. Чтение и запись в файл. Помогите хотя бы с некоторыми... Получилось сделать только...
C++ Vector iterator + offset out of range Вылазит такая ошибка. Подскажите, из-за чего она может вылезти? http://www.cyberforum.ru/cpp-beginners/thread1169478.html
C++ Ошибка при использовании getline для считывания строки из файлового потока
Ошибка находится в 24 строке на точке. Код, подобный этому (а в этой строке фактически 1 в 1 одинаковый) я разбирал в институте. Видимо ошибки совершают и доценты, но мне как-то не до этого. Пожалуйста, помогите найти решение. #include "stdafx.h" #include <iostream> #include <fstream> using namespace std; int _tmain(int argc, _TCHAR* argv) { setlocale(LC_ALL, "RUSSIAN");
C++ Перевести структуру ORDER в класс
Помогите решить! Требуется решить задачу с использованием классов. При этом обязательно оформить методы для выполнения каждого из действий: по вводу данных, выводу их в файл, чтению данных из файла и выводу их на экран, сортировке данных. Дана структура с именем ORDER, состоящая из полей: - расчетный счет плательщика; - расчетный счет получателя; - перечисляемая сумма в руб. Написать...
C++ Обращение к приватным полям классов http://www.cyberforum.ru/cpp-beginners/thread1169454.html
Необходимо создать класс, в котором есть указатель на другой класс и все функции, которые с ним нужно выполнить.В другом классе все основные поля класса. Все поля классов private. Как к ним обращаться?class sotrydnik { private: string surname; string name; int number; /*ifstream &operator >>(ifstream & inp) { getline(inp, surname); getline(inp, name);
C++ Как вывести кириллицу в консоли void first() { char ch; gets(ch); puts(ch); } int main() { first(); подробнее

Показать сообщение отдельно
Slight
0 / 0 / 0
Регистрация: 27.12.2013
Сообщений: 36

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

08.05.2014, 16:57. Просмотров 1164. Ответов 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 минут
Актуально
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru