Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.78/18: Рейтинг темы: голосов - 18, средняя оценка - 4.78
0 / 0 / 0
Регистрация: 29.11.2012
Сообщений: 29

Вычисление площади треугольника по координатам x,y

21.06.2013, 16:15. Показов 3765. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет, задали написать программу вычислить площади треугольника по координатам..данные координат берутся из файла и конечный результат записывается в файл.. А с файлами у меня очень туго..(
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.06.2013, 16:15
Ответы с готовыми решениями:

Вычисление площади треугольника по координатам концов отрезков с ++
Три отрезка заданы координатами своих концов. Определить, можно ли построить из них треугольник, если - да, то вычислить его площадь

Составить функцию вычисления площади треугольника по координатам вершин
Ребят, спасайте, завтра на экзамен нужно принести эту задачку.. Не знаю что делать) Помогите, чтобы программа была написана на начальном...

Определить процедуру вычисления площади треугольника по координатам его вершин
Даны натуральное число n, действительные числа x1, y1, x2, y2,…, xn,yn. Найти площадь n-угольника,вершины которого при некотором...

3
 Аватар для igorrr37
2878 / 2025 / 991
Регистрация: 21.12.2010
Сообщений: 3,771
Записей в блоге: 10
21.06.2013, 20:36
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
#include <iostream>
#include <fstream>
#include <cmath>
#include <stdexcept>
 
struct Point
{
    explicit Point(int const x = 0, int const y = 0) : _x(x), _y(y) {}
    int _x, _y;
};
 
std::istream& operator>> (std::istream& ist, Point& rhs)
{
    return ist >> rhs._x >> rhs._y;
}
 
struct Triangle
{
    explicit Triangle(Point const& a = Point(), Point const& b = Point(), Point const& c = Point()) : _a(a), _b(b), _c(c) {}
 
    double perimeter() const
    {
        return sqrt(pow(_b._x - _a._x, 2) + pow(_b._y - _a._y, 2)) +
                sqrt(pow(_c._x - _b._x, 2) + pow(_c._y - _b._y, 2)) +
                sqrt(pow(_a._x - _c._x, 2) + pow(_a._y - _c._y, 2));
    }
 
    double area() const
    {
        double hp = perimeter() / 2;
        return sqrt(hp *
                    (hp - sqrt(pow(_b._x - _a._x, 2) + pow(_b._y - _a._y, 2))) *
                    (hp - sqrt(pow(_c._x - _b._x, 2) + pow(_c._y - _b._y, 2))) *
                    (hp - sqrt(pow(_a._x - _c._x, 2) + pow(_a._y - _c._y, 2))));
    }
    Point _a, _b, _c;
};
 
std::istream& operator>> (std::istream& ist, Triangle& rhs)
{
    ist >> rhs._a >> rhs._b >> rhs._c;
    if(!ist)
        throw std::runtime_error("operator>> failed");
    return ist;
}
 
int main()
{
    try
    {
        std::fstream fs("in.txt", std::ios::in);
        if(fs.is_open())
        {
            Triangle tr;
            fs >> tr;
            fs.clear();
            fs.close();
            fs.open("out.txt", std::ios::out);
            double area = tr.area();
            std::cout << area << "\n\n";
            fs << area << "\n\n";
            fs.close();
        }
        else
            std::cerr << "Unable to open input file\n";
    }
    catch(std::exception const& exc)
    {
        std::cerr << exc.what() << "\n\n";
    }
    return 0;
}
0
0 / 0 / 0
Регистрация: 29.11.2012
Сообщений: 29
21.06.2013, 21:58  [ТС]
Спасибо, но это сложно..можно по проще..вот пример подсчёта площади, а вот как это в файл записать..
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
#include "stdafx.h"
#include <math.h>
#include <iostream>
using namespace std;
#include <string>
int _tmain(int argc, _TCHAR* argv[])
{
 
 
{  double x1,x2,x3,y1,y2,y3, c,p,s,sg,pp,a,b;
  cout<<"x1="; cin>>x1;
  cout<<"y1="; cin>>y1;
  cout<<"x2="; cin>>x2;
  cout<<"y2="; cin>>y2;
  cout<<"x3="; cin>>x3;
  cout<<"y3="; cin>>y3;
 a = sqrt(((x1-x2)*(x1-x2))+((y1-y2)*(y1-y2))); cout<<" a=" <<a<<endl ;
 b = sqrt(((x1-x3)*(x1-x3))+((y1-y3)*(y1-y3))); cout<<" b=" <<b<<endl ;
 c = sqrt(((x2-x3)*(x2-x3))+((y2-y3)*(y2-y3))); cout<<" c=" <<c<<endl ;
 p = a+b+c;
 
pp=p/2;//считаем полупериметр
sg=sqrt(pp*(pp-a)*(pp- b )*(pp-c)); 
s=0.5*(a*b);
 cout<<"ploshad`=" <<s<<endl;
cout<<"ploshad` gerona=" <<sg<<endl;}
system("pause");
    return 0;
}
0
21.06.2013, 22:02

Не по теме:

по нормальному, площади треугольников, заданных с помощью координат вершин, вычисляют с помощью векторного произведения, не используя никаких радикалов

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
21.06.2013, 22:02
Помогаю со студенческими работами здесь

Определить процедуру вычисления площади треугольника по координатам его вершин
Даны натуральное число n, действительные числа x1, y1, x2, y2,..., xn, yn. Найти площадь n угольника, вершины которого при некотором...

Вычисление площади по координатам - указать на ошибки
что тут не так,не подскажете? файл point.h #ifndef POINT_H_INCLUDED #define POINT_H_INCLUDED struct point {double x;double y;}; ...

Нахождение площади параллелограмма, треугольника и объема параллелепипеда, тетраэдра по координатам вершин
Нахождение площади параллелограмма, треугольника и объема параллелепипеда, тетраэдра по координатам вершин. Задается пользователем:...

Вычисление периметра треугольника по заданным координатам вершин
Добрый день, по такому условию &quot; Составить программу, которая вычисляет периметр треугольника, если заданы координаты вершин ....

Вычисление площади равностороннего треугольника
Здравствуйте! помогите пожалуйста правильно написать формулу на с++ для вычисления площади и высоты в равностороннем треугольнике. ...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru