Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/25: Рейтинг темы: голосов - 25, средняя оценка - 4.64
8 / 7 / 1
Регистрация: 08.04.2021
Сообщений: 151

Треугольники

21.06.2021, 21:03. Показов 4891. Ответов 3
Метки с++ (Все метки)

Студворк — интернет-сервис помощи студентам
Треугольники
У Глеба есть n отрезков.

Глеб — большой любитель геометрии и всяких бесполезных действий. Поэтому он хочет выяснить, сколько различных невырожденных треугольников у него получится составить из всех имеющихся у него отрезков.

Два треугольника считаются различными, если хотя бы одна из сторон треугольников различна.

Два отрезка считаются различными, если различаются их номера в порядке ввода.

Входные данные

В первой строке записано число n, 3≤n≤4000.
В следующих строках записаны длины отрезков 1≤ai≤109.

Выходные данные

Вывести одно число — количество треугольников.

Примеры
Ввод
Вывод
3
1
1
10
0
3
3
4
5
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
#include <iostream>
#include <set>
#include <vector>
using namespace std;
 
int main()
{
    int n; cin >> n;
    vector<int> vct(n); // вектор с длинами отрезков
    for (int i = 0; i < n; i++)
        cin >> vct[i];
    set<multiset<int>> st;
    for (int i = 0; i < vct.size(); ++i)
    {
        for (int j = 0; j < vct.size(); ++j)
        {
            if (j != i)
            {
                for (int k = 0; k < vct.size(); ++k)
                {
                    if (k != i && k != j)
                    {
                        if (vct[i] < vct[j] + vct[k] && vct[j] < vct[i] + vct[k] && vct[k] < vct[i] + vct[j])
                        {
                            st.insert({ vct[i], vct[j], vct[k] });
                        }
                    }
                }
            }
        }
    }
    cout << st.size();
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.06.2021, 21:03
Ответы с готовыми решениями:

Треугольники
реугольники У Глеба есть n отрезков. Глеб — большой любитель геометрии и всяких бесполезных действий. Поэтому он хочет выяснить,...

Треугольники
Интересно, можно ли на C++ (или любом другом языке) корректно определить класс треугольник, положив в его основу три хорошо известных...

Треугольники
Доброй ночи\утро\день всем! Сразу прошу прощения, если такая тема уже есть - но совесть моя почти чиста - искала - и не нашла ничего...

3
 Аватар для ПерС
587 / 490 / 371
Регистрация: 05.11.2013
Сообщений: 1,271
Записей в блоге: 6
21.06.2021, 21:13
Цитата Сообщение от alimaaa Посмотреть сообщение
геометрии и всяких бесполезных действий

Не по теме:

Отлично. Фурсенко?

0
4 / 4 / 0
Регистрация: 11.08.2020
Сообщений: 14
22.07.2022, 11:31
ну твой алгоритм за O(n3)
я знаю алгоритм за O(n2log(n))

попробую реализовать и скину, посмотрим что выйдет.
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
23.07.2022, 16:59
Задача: "Треугольники"
Там как раз за n^2*log(n).

Добавлено через 5 минут
Если коротенечко, то


Не надо в первом цикле идти до конца, это не имеет смысла
Цитата Сообщение от HWAA Посмотреть сообщение
for (int i = 0; i < vct.size() - 2; ++i)
Можно вдвое уменьшить количество действий, начав второй вложенный цикл с i+1 до siz
Цитата Сообщение от HWAA Посмотреть сообщение
for (int j = i + 1; j < vct.size() - 1; ++j)
{
Если массив исходный отсортировать, тогда вместо третьего цикла можно воспользоваться бинарным поиском, который значительно быстрее линейного.

Получаем n^2 * log(n) вместо n^3.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.07.2022, 16:59
Помогаю со студенческими работами здесь

Треугольники
На плоскости задано n точек с целочисленными координатами. Никакие три точки не лежат на одной прямой. Определить k - количество...

Треугольники (C\C++)
Написать программу, по длинам сторон распознающую среди всех треугольников ABC прямоугольные. Если таковых нет, то вычислить величину угла...

треугольники
#include &lt;math.h&gt; #include &lt;iostream&gt; #include &quot;class.h&quot; using namespace std; tre1::tre1(double){ a=0; ...

Существуют ли треугольники a, b, c, d
Задали лабораторную по C++, у самой не получается сделать, не знаю даже как это реализовать, помогите пожалуйста... &quot;Даны четыре...

Перисикаются ли треугольники
Здравствуйте :beach: Имеются по три вершины двух треугольников. Задача в том проверить пересекаются треугольники. Заранее спасибо! :)


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru