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

Найти наименьший из углов треугольника

11.11.2020, 16:29. Показов 2629. Ответов 25

Студворк — интернет-сервис помощи студентам
Здравствуйте, подскажите как сделать задачу. Совсем не могу разобраться
C++
На плоскости задан треугольник длинами своих сторон.
Найти наименьший из углов треугольника в градусах. Значения сторон вводить в диалоге, иметь возможность повторного обращения.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.11.2020, 16:29
Ответы с готовыми решениями:

Вычисление одного из углов треугольника, когда заданы значения двух других углов
Написать программу вычисления одного из углов треугольника, когда заданы значения двух других углов. Рекомендуемый вид экрана во время...

Простая задача: найти суму углов треугольника
Итак, имеется такая студенческая задача: Треугольник задан тремя точками на плоскости(все данный заведомо правильные и имеется ввиду...

Найти площадь треугольника, если известны координаты его углов
Напишите программу, которая вычисляет площадь треугольника, если известны координаты его углов. Введите координаты углов (числа...

25
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 16:44
1. запрашиваете ввод трех переменных - стороны треугольника
2. по введенным значениям вычисляете площадь по формуле Герона, только сперва вычисляете подкоренное выражение и анализируете это значение: если оно отрицательно - треугольник не существует, если равно нулю - треугольник вырожденный, наименьший угол равен 0 градусов, если значение положительно и больше нуля идем дальше.
3. Извлекаете квадратный корень и получаете площадь
4. далее из формулы площади S = a * h / 2 выражаете высоту через основание (любая из введенных сторон)
5. воспользовавшись одним из определений синуса угла: "в прямоугольном треугольнике синус угла равен отношению противолежащего катета к гипотенузе" - вычисляете углы через арксинус отношения высоты к стороне треугольника образующей гипотенузу прямоугольного треугольника с высотой h.
6. находите наименьший угол
7. выводите результат.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 16:55
Цитата Сообщение от Annemesski Посмотреть сообщение
вычисляете площадь по формуле Герона
Annemesski, зачем ТС Герон если есть формула косинусов ?
https://www.cyberforum.ru/cgi-bin/latex.cgi?cos(\alpha)=\frac{{b}^{2}+{c}^{2}-{a}^{2}}{2bc}
0
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 16:57
Цитата Сообщение от Yetty Посмотреть сообщение
зачем ТС Герон если есть формула косинусов ?
есть, но один пень проверять существование треугольника, это можно сделать по Герону, а его результат использовать для вычисления углов, формулы чуть проще чем теорема синусов или косинусов.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 17:07
Цитата Сообщение от Annemesski Посмотреть сообщение
пень проверять существование треугольника, это можно сделать по Герону
во-первых это не требуется по задаче:
Цитата Сообщение от AnastasiaYakub Посмотреть сообщение
На плоскости задан треугольник
а если бы даже и требовалось, треугольник существует когда сумма двух его сторон больше третьей. вычислять площадь, в частности по теореме Герона конечно не нужно
0
 Аватар для Celly
158 / 148 / 25
Регистрация: 23.01.2011
Сообщений: 319
11.11.2020, 17:15
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
#include <iostream>
#include <cmath>
 
bool IsValidTriangle(int a, int b, int c)
{
    if (!((a + b) > c))
        return false;
 
    if (!((b + c) > a))
        return false;
 
    if (!((a + c) > b))
        return false;
 
    return true;
}
 
/*
            beta
             /\
            /  \
           /    \
         a/      \b
         /        \
        /          \
  alpha/____________\gamma
             c
 */
 
int main(int argc, const char * argv[])
{
    double a = 0.0, b = 0.0, c = 0.0;
    std::cout << "Input a = ";
    std::cin >> a;
    std::cout << "Input b = ";
    std::cin >> b;
    std::cout << "Input c = ";
    std::cin >> c;
 
    if (!IsValidTriangle(a, b, c))
    {
        std::cout << "Invalid triangle -- a = " << a << ", b = " << b << ", c = " << c << std::endl;
        return -1;
    }
 
    double alpha = 0.0, beta = 0.0, gamma = 0.0;
 
    alpha = std::acos((a * a + c * c - b * b)/(2 * a * c)) * 180 / M_PI;
    beta = std::acos((a * a + b * b - c * c)/(2 * a * b)) * 180 / M_PI;
    gamma = std::acos((b * b + c * c - a * a)/(2 * b * c)) * 180 / M_PI;
 
    std::cout << "alpha = " << alpha << std::endl;
    std::cout << "beta  = " << beta << std::endl;
    std::cout << "gamma = " << gamma << std::endl;
 
    return 0;
}
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 17:18
Celly, почему тип параметров функции int если стороны double ?

также требуется найти min:
Цитата Сообщение от AnastasiaYakub Посмотреть сообщение
Найти наименьший из углов треугольника в градусах.
0
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 17:22
Yetty, в моем решении нужно
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 17:22
Цитата Сообщение от AnastasiaYakub Посмотреть сообщение
возможность повторного обращения
...
0
 Аватар для Celly
158 / 148 / 25
Регистрация: 23.01.2011
Сообщений: 319
11.11.2020, 17:24
Цитата Сообщение от Yetty Посмотреть сообщение
Celly, почему тип параметров функции int если стороны double ?
На автомате, когда функцию писал.

Цитата Сообщение от Yetty Посмотреть сообщение
также требуется найти min:
Для самостоятельной работы.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 17:26
Цитата Сообщение от Annemesski Посмотреть сообщение
в моем решении нужно
Ваше решение, мягко говоря нерационально

Добавлено через 59 секунд
Цитата Сообщение от Celly Посмотреть сообщение
Для самостоятельной работы.
в таких случаях предупреждают, а не просто сбрасывают код. в целом конечно направление решения верное, только ТС конечно лучше оформить вычисления в виде функции
0
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 17:31
Yetty, чем оно не рационально?
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 17:41
Цитата Сообщение от Annemesski Посмотреть сообщение
чем оно не рационально?
сравните предложенный Вами способ решение с кодом сообщения #6 и сделайте выводы сами

Добавлено через 4 минуты
угол определяется непосредственно - для его определения площадь треугольника находить не нужно
0
0 / 0 / 0
Регистрация: 09.11.2020
Сообщений: 20
11.11.2020, 17:42  [ТС]
Всем Спасибо! Задача уже решена, покопалась в формулах и все получилось) решение больше не требуется)
0
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 17: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
#define _USE_MATH_DEFINES
#include <iostream>
#include <cmath>
#include <algorithm>
 
int main()
{
    double a, b, c;
    std::cin >> a >> b >> c;
    double p = (a + b + c) / 2;
    double Ss = p *(p - a) * (p - b) * (p - c);
    if (p < 0)
        std::cout << "impossible" << std::endl;
    else if (p < 1e:8)
        std::cout << "minimum = 0" << std::endl;
    else
    {
        double h = 2 * sqrt(Ss) / a;
        double alpha = asin(h / b);
        double betta = asin(h / c);
        double gamma = M_PI - alpha - betta;
        std::cout << "minimum = " << 180 / M_PI * std::min(std::min(a, b), c) << std::endl;
    }
 
    return 0;
}
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 18:48
Цитата Сообщение от Annemesski Посмотреть сообщение
сравниваем
и ? Вы не можете сделать вывод или не можете подсчитать количество действий ? делаю это вместо Вас:
количество действий, то есть математических операций (для нахождения cos (или sin)):
3+6+1+2+1 = 13 (Ваш вариант)
5+2+1 = 8 (вариант сообщения #6)

кроме того наличие sqrt и трёх делений ещё больше замедляет работу
0
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 18:55
Yetty, научитесь считать: количество действий в посте 6 - 8 * 2 + 2 = 18 (если последний угол считать как у меня, в оригинале там 24), у меня 16, а если если учитывать дороговизну корня, то учитывайте и то, что с вашей стороны 10 умножений и 2 деления у меня 4 умножения и 3 деления 12 против 7.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 19:22
Annemesski, научитесь читать, что Вам пишут:
Цитата Сообщение от Yetty Посмотреть сообщение
для нахождения cos (или sin)
у Вас - 13 действий против 8 действий в другом варианте
0
 Аватар для Annemesski
2644 / 1311 / 473
Регистрация: 08.11.2016
Сообщений: 3,605
11.11.2020, 19:31
Yetty, в итоге это не даёт экономии, взялись считать, считайте решение полностью, у меня вычисление второго угла обходится дешевле, и пусть что вычисление первого дороже, суммарно по трем углам все равно дешевле. Ну да Гильберт Вам судья.
0
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
11.11.2020, 19:54
Цитата Сообщение от Annemesski Посмотреть сообщение
количество действий в посте 6 - 8 * 2 + 2 = 18 (если последний угол считать как у меня, в оригинале там 24), у меня 16
при правильной записи (с доп.переменными qa=a*a, qb=b*b, qc=c*c) действий будет меньше чем в Вашем варианте

про sqrt и деления уже говорил, повторяться смысла не вижу
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
11.11.2020, 19:54
Помогаю со студенческими работами здесь

Треугольник задан величинами своих углов и радиусом вписанной окружности. Найти стороны треугольника.
Треугольник задан величинами своих углов и радиусом вписанной окружности. Найти стороны треугольника. help!!)

Ввести длину стороны треугольника и величины двух прилегающих углов и вывести площадь этого треугольника
Ввести длину стороны треугольника и величины двух прилегающих углов и вывести площадь этого треугольника. c++

Как найти вершины прямоугольного треугольника через вершину прямого угла, катет и известные значения углов
https://pp.userapi.com/c824203/v824203420/3ab57/Cm9LlhdgdfA.jpg https://pp.userapi.com/c824203/v824203420/3ab70/R6zbILPPYls.jpg ...

На плоскости задан треугольник длинами своих сторон, найти наименьший из углов треугольника
Прошу помогите написать программу в паскале, не пойму как ее делать. На плоскости задан треугольник длинами своих сторон найти...

Даны длины сторон треугольника. Найти величины всех углов этого треугольника
Даны длины сторон треугольника. Найти величины всех углов этого треугольника Что-то не сходится, но не могу понять что... VAR a, b,...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Создаем микросервисы с Go и Kubernetes
golander 02.07.2025
Когда я только начинал с микросервисами, все спорили о том, какой язык юзать. Сейчас Go (или Golang) фактически захватил эту нишу. И вот почему этот язык настолько заходит для этих задач: . . .
C++23, квантовые вычисления и взаимодействие с Q#
bytestream 02.07.2025
Я всегда с некоторым скептицизмом относился к громким заявлениям о революциях в IT, но квантовые вычисления - это тот случай, когда революция действительно происходит прямо у нас на глазах. Последние. . .
Вот в чем сила LM.
Hrethgir 02.07.2025
как на английском будет “обслуживание“ Слово «обслуживание» на английском языке может переводиться несколькими способами в зависимости от контекста: * **Service** — самый распространённый. . .
Использование Keycloak со Spring Boot и интеграция Identity Provider
Javaican 01.07.2025
Два года назад я получил задачу, которая сначала показалась тривиальной: интегрировать корпоративную аутентификацию в микросервисную архитектуру. На тот момент у нас было семь Spring Boot приложений,. . .
Содержание темы с примерами на WebGL
8Observer8 01.07.2025
Все примеры из книги Мацуды и Ли в песочнице JSFiddle Пример выводит точку красного цвета размером 10 пикселей на WebGL 1. 0 и 2. 0 WebGL 1. 0. Передача координаты точки из главной программы в. . .
Основы WebGL. Простой треугольник
8Observer8 01.07.2025
Простой треугольник без трансформаций. Для трансформаций можно использовать glMatrix, как в примере: https:/ / plnkr. co/ edit/ qT6ZTwvncLPRamK5?preview На русском: . . .
Полиглотные микросервисы на C# и .NET
ArchitectMsa 30.06.2025
Полиглотная архитектура появилась не из желания усложнить жизнь разработчикам. Она родилась из практической необходимости решать разные задачи наиболее эффективным способом. В одном из проектов. . .
Стратегии кеширования
Javaican 29.06.2025
Кеширование — это хранение часто запрашиваемых данных в быстром хранилище (обычно в памяти), чтобы не обращаться к более медленному первоисточнику. Казалось бы, все просто. Но за этой простотой. . .
Наблюдаемость приложений ASP.NET Core с OpenTelemetry, Prometheus и Grafana
ArchitectMsa 29.06.2025
Наблюдаемость (observability) – это ключевое свойство современной системы, позволяющее понимать её внутреннее состояние на основе внешних данных. Если мониторинг отвечает на вопрос "что случилось?",. . .
Четыре главных модели отношений классов в с++
russiannick 28.06.2025
Продолжаю крестовый поход против c++. ideone. com/ юзаю для проверки валидности кода. Насчитал 4 модели отношений классов: одиночный класс, равноправные классы, слейв - мастер, терминатор. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru