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

Максимальный треугольник - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Реализовать функцию линейного поиска элемента в массиве http://www.cyberforum.ru/cpp-beginners/thread780292.html
1) Реализовать функцию линейного поиска элемента в массиве (принимает массив и искомое значение(ключ), возвращает индекс найденного элемента или -1, если такового нет); Правила форума п. 5.16:...
C++ Вывод через структуры ,как сделать? #include <iostream> #include <math.h> using namespace std; class drob { public: double ch; http://www.cyberforum.ru/cpp-beginners/thread780270.html
Найти точки пересечения касательных с окружностью C++
Даны координаты центра и радиус R окружности, координаты точки. Найти точки пересечения касательных с окружностью Даны координаты центра (xc,yc) и радиус R окружности, координаты точки (x,y)....
C++ Содержательно сформулировать результат выполнения функции
Пожалуйста, объясните, что выполняет каждая функция. Заранее спасибо! //------------------------------------------------- 1 void F1(char c) { int i,j; for (i=0; c !='\0'; i++); for (j=0,i--;...
C++ Определить общий вид степенного ряда, вычисляемого в данной функции http://www.cyberforum.ru/cpp-beginners/thread780210.html
Помогите, пожалуйста сформулировать словами, что выполняет каждый код: double sum(double x,double eps) { double s,sn; int n; for (s=0, sn = 1, n=1; fabs(sn) > eps; n++) { s += sn; sn= - sn...
C++ Станное поведение указателя Пробовал "отладить" код и натолкнулся на грабли (см. комментарии): void itoa(long n, char* str) { char *s = str; while (n) { *s++ = n % 10 + '0'; n /= 10; } ... подробнее

Показать сообщение отдельно
snw
10 / 10 / 0
Регистрация: 11.10.2012
Сообщений: 93

Максимальный треугольник - C++

06.02.2013, 11:55. Просмотров 371. Ответов 3
Метки (Все метки)

Даны n точек заданные координатами. Требуется найти среди этих точек треугольник с максимальной площадью.

Входные данные:
5
0 0
0 2
1 0.5
0.5 1
2 0

Выходные(площадь треугольника и вершины из которых он получился)
2.00
1 2 5
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
#include <fstream>
 
using namespace std;
 
int main()
{
    int i, j, k, n, a = 0, b = 0, c = 0;
    double S1 = 0.0,
           S2 = 0.0,
           S3 = 0.0,
           max1 = 0.0,
           max2 = 0.0,
           max3 = 0.0,
           SUPER_MAX = 0.0;
 
    ifstream in("input.txt");
    ofstream out("output.txt");
 
    in >> n;
 
    double * x = new double[n];
    double * y = new double[n];
    
    for(i = 0; i < n; i++)
    {
        in >> x[i];
        in >> y[i];
    }
 
    for(i = 0; i < n; i++)
    {
        S1 = abs((y[i - 1] + y[i]) * (x[i] - x[i - 1]) - (y[0] + y[i])*(x[i] - x[0]));
        max1 = S1;
        
        
        for(j = i + 2; j < n; j++)
        {
            S2 = abs((y[j - 1] + y[j]) * (x[j] - x[j - 1]) - (y[0] + y[j]) * (x[j] - x[0]));
            max2 = S2;
            
 
            for(k = j; k < n; k++)
            {
                S3 = abs((y[k - 1] + y[k]) * (x[k] - x[k - 1]) - (y[0] + y[k]) * (x[k] - x[0]));
                max3 = S3;
                    
            }   
 
        }
        
        if(max1 > max2 && max1 > max3)
        {
            SUPER_MAX = max1;
            a = i;
            b = j;
            c = k;
        }
        else
            if(max2 > max1 && max2 > max3)
            {
                SUPER_MAX = max2;
                a = i;
                b = j;
                c = k;
            }
            else
                if(max3 > max2 && max3 > max1)
                {
                    SUPER_MAX = max3;
                    a = i;
                    b = j;
                    c = k;
                }
        
    }
 
    out << SUPER_MAX << endl
        << a << " " << b << " "  << c << endl
        << max1 << " " << max2 << " " << max3;
            
 
}
помогите разобраться с циклами 2 и 3.. видать они на повтор идут, площадь то сошлась с ответам по этим входным данным, а вершины не в какую не идут
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru