Форум программистов, компьютерный форум, киберфорум
Наши страницы

Подскажите, где может быть ошибка (структуры)? (скорее всего где-то амперсенд нужен, все вроде проверил) - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Даны вещественные числа А > 1 и В http://www.cyberforum.ru/cpp-beginners/thread854344.html
Даны вещественные числа А > 1 и В. Распечатать все числа вида сi = Аi (i = 1,2,...), меньшие В. Помогите решить в C++.
C++ Пояснения кода Вариант 5. Сформировать одномерный массив. Удалить из него K элементов, начиная с заданного номера, добавить K элементов, начиная с заданного номера. объясните пожалуйста отмеченные мною части... http://www.cyberforum.ru/cpp-beginners/thread854324.html
Написать функцию, которая удаляет все лишние пробелы C++
Доброго дня суток. Помогите пожалуйста.. Нужно написать функцию, которая удаляет все лишние пробелы, т. е. из нескольких подряд идущих пробелов оставить только один. А также есть такой код: ...
C++ Сортировка Шелла
В алфавитном порядке по фамилии алгоритмом Шелла #include <iostream> #include <string> #include <fstream> #include <iomanip> using namespace std; ifstream in("input.txt"); ofstream...
C++ RSA шифрование http://www.cyberforum.ru/cpp-beginners/thread854275.html
Народ помогите пожалуйста! Вот функция генерации ключей, вот только то нормально шифрует и расшифровывает, то криво, в чем проблема? keys kluch(Random^ rnd) { keys kl; int p, q, n, e, d,...
C++ Наследование чисто вируальной функции Доброго времени суток. Пишу класс описывающий структуру файла. Имею класс relHeader c 2 чисто виртуальными функциями. Ее наследуют еще 3 класса, но при попытке реализации этих функций через... подробнее

Показать сообщение отдельно
Leonidiusi

Подскажите, где может быть ошибка (структуры)? (скорее всего где-то амперсенд нужен, все вроде проверил) - C++

02.05.2013, 19:10. Просмотров 405. Ответов 1
Метки (Все метки)

написать универсальный тип, который представляет точку на плоскости в координатах (х, у) и в полярных координатах. Написать функцию для подсчета площади треугольника, заданного 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
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
#include <iostream.h>
#include <conio.h>
#include <stdio.h>
#include <string.h>
#include <ctype.h>
#include <math.h>
typedef enum { stand, polar} Mode;
 
typedef struct
{
     Mode coord_mode;
     union
      {
       struct {double x, y;} s;
       struct {double r, phi;} p;
      } syst;
} tochka;
 
void get (tochka z) {
int k;
cout<<"Vvod systemy (standart = 0, polar = 1)";
cin>>k;
if (k==1) {
     z.coord_mode = stand;
     cout<<"Vvod (x,y)";
     cin>>z.syst.s.x>>z.syst.s.y;
     }
if (k==2) {
     z.coord_mode = polar;
     cout<<"Vvod (r,phi)";
     cin>>z.syst.p.r>>z.syst.p.phi;
     }
}
 
double plo (tochka a, tochka b, tochka c) {
double sq;
 
switch (a.coord_mode) {
case stand: switch (b.coord_mode)
         {
         case stand: switch (c.coord_mode)
               {
               case stand: sq = (abs((b.syst.s.x-a.syst.s.x)*(c.syst.s.y-a.syst.s.y)-(c.syst.s.x-a.syst.s.x)*(b.syst.s.y-a.syst.s.y))/2);
               break;
               case polar: sq = (abs((b.syst.s.x-a.syst.s.x)*((c.syst.p.r)*(sin(c.syst.p.phi))-a.syst.s.y)-((c.syst.p.r)*(cos(c.syst.p.phi))-a.syst.s.x)*(b.syst.s.y-a.syst.s.y))/2);
               break;
               default: break;
               }
         case polar: switch (c.coord_mode)
               {
               case stand: sq = (abs(((b.syst.p.r)*(cos(b.syst.p.phi))-a.syst.s.x)*(c.syst.s.y-a.syst.s.y)-(c.syst.s.x-a.syst.s.x)*((b.syst.p.r)*(sin(b.syst.p.phi))-a.syst.s.y))/2);
               break;
               case polar: sq = (abs(((b.syst.p.r)*(cos(b.syst.p.phi))-a.syst.s.x)*((c.syst.p.r)*(sin(c.syst.p.phi))-a.syst.s.y)-((c.syst.p.r)*(cos(c.syst.p.phi))-a.syst.s.x)*((b.syst.p.r)*(sin(b.syst.p.phi))-a.syst.s.y))/2);
               break;
               default: break;
               }
 
         }
case polar: switch (b.coord_mode)
         {
         case stand: switch (c.coord_mode)
               {
               case stand: sq = (abs((b.syst.s.x-(a.syst.p.r)*(sin(a.syst.p.phi)))*(c.syst.s.y-(a.syst.p.r)*(cos(a.syst.p.phi)))-(c.syst.s.x-(a.syst.p.r)*(sin(a.syst.p.phi)))*(b.syst.s.y-(a.syst.p.r)*(cos(a.syst.p.phi))))/2);
               break;
               case polar: sq = (abs((b.syst.s.x-(a.syst.p.r)*(sin(a.syst.p.phi)))*((c.syst.p.r)*(sin(c.syst.p.phi))-(a.syst.p.r)*(cos(a.syst.p.phi)))-((c.syst.p.r)*(cos(c.syst.p.phi))-(a.syst.p.r)*(sin(a.syst.p.phi)))*(b.syst.s.y-(a.syst.p.r)*(cos(a.syst.p.phi))))/2);
               break;
               default: break;
               }
         case polar: switch (c.coord_mode)
               {
               case stand: sq = (abs(((b.syst.p.r)*(cos(b.syst.p.phi))-(a.syst.p.r)*(sin(a.syst.p.phi)))*(c.syst.s.y-(a.syst.p.r)*(cos(a.syst.p.phi)))-(c.syst.s.x-(a.syst.p.r)*(sin(a.syst.p.phi)))*((b.syst.p.r)*(sin(b.syst.p.phi))-(a.syst.p.r)*(cos(a.syst.p.phi))))/2);
               break;
               case polar: sq = (abs(((b.syst.p.r)*(cos(b.syst.p.phi))-(a.syst.p.r)*(sin(a.syst.p.phi)))*((c.syst.p.r)*(sin(c.syst.p.phi))-(a.syst.p.r)*(cos(a.syst.p.phi)))-((c.syst.p.r)*(cos(c.syst.p.phi))-(a.syst.p.r)*(sin(a.syst.p.phi)))*((b.syst.p.r)*(sin(b.syst.p.phi))-(a.syst.p.r)*(cos(a.syst.p.phi))))/2);
               break;
               default: break;
               }
 
         }
}
return sq;
}
 
int main()
{
clrscr();
tochka a,b,c;
cout<<"Vvod 3h tochek";
get(a);
get(b);
get(c);
cout<<plo(a,b,c);
getch();
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru