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

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

02.05.2013, 19:10. Просмотров 512. Ответов 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();
}
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.05.2013, 19:10
Ответы с готовыми решениями:

Совершенно не представляю где ошибка, вроде всё проверил
:help: #include &lt;iostream&gt; #include &lt;cmath&gt; #include &lt;iomanip&gt;//требуется для ввода-вывода...

Подскажите где в программе может быть ошибка
#include &lt;iostream&gt; #include &lt;math&gt; #include &lt;conio&gt; #include &lt;time.h&gt; #include &lt;stdio.h&gt;...

Может быть я что-то не понимаю? Подскажите, где ошибка...
Здравствуйте! Снова я, наверняка уже поднадоевший вам @asn007, со своими дибильными вопросами...

Подскажите почему не работает программа. Может быть где то ошибка в коде
using System; using System.Collections.Generic; using System.Linq; using System.Text; ...

Подскажите, где искать ошибку? и в чем она может быть?
Задача 'Синхронизация папок с подпиской для &quot;.........&quot;.' сообщила об ошибке (0x8004DF0B) :...

1
IrineK
Заблокирован
02.05.2013, 19:17 2
На первый поверхностный взгляд: как поженить просьбу ввести 0 или 1 в строке 21 с проверками на 1 и 2 в строках 23 и 28?
0
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.05.2013, 19:17

Где может быть ошибка?
Уважаемые форумчане, столкнулся со следующей проблемой... Написал макрос, в котором в столбце AK...

Где может быть ошибка?
#include &lt;iostream&gt; #include &lt;queue&gt; #include &lt;string&gt; using namespace std; int main(){ ...

Где может быть ошибка?
Здравствуйте, есть файл Prepods.xml вот его содержимое: &lt;?xml version=&quot;1.0&quot; encoding=&quot;utf-8&quot;?&gt;...


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

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

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