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

Правильный N-многоугольник - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ STATUS_STACK_BUFFER_OVERRUN http://www.cyberforum.ru/cpp-beginners/thread1108715.html
Здравствуйте, Сделана (вроде логично) простая программка. Не работает из-за переполнения буфера О_о trace to cursor показал что из функции вылетаю после указания/чтения 7го эл-та матрицы. Как...
C++ Преобразовать массив таким образом, чтобы сначала располагались все элементы, модуль которых не превышает 1 В одномерном массиве, состоящей из n вещественных элементов, вычислить: 1) номер минимального элемента массива; 2) сумму элементов массива, расположенных между первым и вторым отрицательными... http://www.cyberforum.ru/cpp-beginners/thread1108689.html
C++ работа с внешними ресурсами
Написать программу копирования содержимого текстового файлав конец другого файла. Написать программу для Windows по созданию окна, куда бы выводилась текстовая информация. Заранее спасибо.
C++ Графика
Товарищи программисты помогите с задачей пожалуйста, что бы работала в Visual Studio 2010. Написать программу, которая выводит на экран точечный график функции y= 2^x. Диапазон изменения аргумента –...
C++ Используя рекурсию, перемножить 2 натуральных числа не используя операции умножения и иметь логарифмическую сложность http://www.cyberforum.ru/cpp-beginners/thread1108679.html
Программа должна перемножать 2 натуральных числа не используя операции умножения и иметь логарифмическую сложность(помогите написать хотя бы рекурсивную функцию я то я вообще не могу вьехать))
C++ Блочная сортировка В данной программе происходит сортировка фамилий по алфавиту.Мне же требуется сортировка всего массива структур. То есть структуры должны стоять в том порядке, в котором должны стоять(по алфавиту)... подробнее

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

Правильный N-многоугольник - C++

01.03.2014, 22:54. Просмотров 308. Ответов 0
Метки (Все метки)

Всем привет! Есть задание:
Кликните здесь для просмотра всего текста
А) Правильный N-многоугольник с заданным числом сторон, длиной стороны и координатами центра. Операции: площадь, радиус описанной и вписанной окружностей, принадлежность точки к внутренности многоугольника (ориентация многоугольника произвольная).
Б) Правильный N-многоугольник в пространстве (лежащий в плоскости, заданной по трем точкам, ориентация многоугольника на плоскости произвольная). Дополнительные операции: лежит ли точка в плоскости многоугольника, объем N- гранной пирамиды с заданной вершиной.

смог часть реализовать, но столкнулся с проблемой, как определить принадлежность точки к внутренности многоугольника, и задание под Б) . Подскажите пожалуйста, как реализовать, или где прочитать.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include "stdafx.h"
#include <iostream>
#include "Class.h"
using namespace std;
 
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_CTYPE, "Russian");
    Figure temp(5,4,0,0);
    cout << "r = " << temp.radius_of_described_circle() << endl;
    cout << tan((RadToGrad(45))) << endl;
    system("pause");
    return 0;
}
Class.h
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
 
#include <math.h>
#define pi  3.141592
 
struct coordinaty
{
    int x;
    int y;
};
 
struct Figure_element
{
    int N; //количество сторон
    double len_stor; //длина стороны
    coordinaty centr; //координаты центра
};
 
class Figure
{
public:
    Figure();
    Figure(int N, double len, int x, int y);
    double Area_of_polygon();
    double radius_of_inscribed_circle();
    double radius_of_described_circle();
    ~Figure();
 
private:
    Figure_element figure;
};
 
Figure::Figure() //конструктор по умолчанию
{
    figure.N = 5;
    figure.len_stor = 1;
    figure.centr.x = 0;
    figure.centr.y = 0;
};
 
Figure::Figure(int N, double len, int x, int y)//пользовательский конструктор
{
    figure.N = N >= 3 ? N : 5;
    figure.len_stor = len > 0 ? len : 1;
    figure.centr.x = x;
    figure.centr.y = y;
};
 
Figure::~Figure()//деструктор здесь не нужен
{
 
};
 
/*S=r·p=(1/2)*r·n·a*/
/*n — число сторон правильного многоугольника
p — полупериметр правильного многоугольника
a — сторона правильного многоугольника
r — радиус вписанной окружности правильного многоугольника*/
double Figure::Area_of_polygon() //площадь правильного многоугольника
{
    return 0.5 * radius_of_inscribed_circle() * figure.N* figure.len_stor;
};
 
double RadToGrad(double rad) //перевод из радиан в градусы
{
    return rad * pi / 180;
};
 
 
//нахождение радиуса вписанной окружности
//формула: len/(2*tg(360/2n))
double Figure::radius_of_inscribed_circle() 
{
    return figure.len_stor / tan(RadToGrad((double)(180 / figure.N))) / 0.2e1;
};
 
//нахождение радиуса описанной окружности
//формула: len/(2*sin(360/2n))
double Figure::radius_of_described_circle()
{
    return figure.len_stor / sin(RadToGrad((double)(180 / figure.N))) / 0.2e1;
};
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru